jquery ui draggable,droppable 學習總結

剛接觸的時候,分不清draggable和droppable的區別,瞎弄了一會,其實很簡單,draggable就是「拖」的功能,droppable就是「放」的功能。css

draggable()是被拖動的元素  而droppable()是盛放被拖動元素的容器 html

原文地址:jquery ui(二)draggable,droppable 學習總結jquery

1、先上一個簡單例子

一、代碼

< script src=" http://code.jquery.com/jquery-1.9.1.js"></ script>
< script src=" http://code.jquery.com/ui/1.10.2/jquery-ui.js"></ script>
< div id="draggable" class="ui-widget-content">
  < p>Drag me to my target--from ifxoxo.com</ p>
</ div>
< div id="droppable" class="ui-widget-header">
  < p>Drop here  -- from ifxoxo.com</ p>
</ div>
<script>
  $(function() {
    // 初始化#draggable 能夠被拖動
    $( "#draggable" ).draggable();  
   // 初始化,有東西拖到#droppable時,彈出alert窗口  
   $( "#droppable" ).droppable({   
      drop: function( event, ui ) { 
          alert("has drop!--from ifxoxo.com");
      }
    });
  });
  </script>

二、截圖/

可拖拽--ifxoxo.com

拖動 #draggable以前的截圖數組

丟下以後截圖--ifxoxo.com

把#draggable 丟到 #droppable 以後的截圖瀏覽器

2、具體用法

一、須要加載的JS ,jquery 須要在jquery-ui以前

二、頁面上的HTML

(1)拖動的element

 //能夠是任何html元素,一個圖片,一個div,或者一個 A 標籤
  < div id="draggable" class="ui-widget-content">
   < p> 這是一個能夠拖動的元素--from ifxoxo.com</ p>
  </ div>

(2) 若是須要指定放下到哪裏,則須要寫一個接受的元素

  //下面是一個DIV
  < div id="droppable" class="ui-widget-header">
     < p>能夠拖動到這裏來  -- from ifxoxo.com</ p>
  </ div>

三、主要的JS代碼

(1)初始化draggable(可拖動)

draggable()函數有許多參數和用法,詳見2、4app

    // 初始化#draggable 能夠被拖動
    $( "#draggable" ).draggable({
       //這裏是一些參數
    });

(2)初始化#droppable,當有東西丟下時,執行

droppable()函數有許多參數和用法(詳見2、5)ssh

    $( "#droppable" ).droppable({   
      drop: function( event, ui ) { 
        alert("has drop!--from ifxoxo.com");
      }
    });

四、draggable()函數的其餘參數

(1)回調函數

有start, stop, drag等事件,這些函數都接受兩個參數:event和ui。
start: 拖動開始, 指鼠標按下, 開始移動.
drag: 拖動過程當中鼠標移動.
stop: 拖動結束.函數

          //初始化時設置事件.
          $('.selector').draggable({
             start: function(event, ui){ alert(this); },
             drag: function(event, ui) { alert(this); },
             stop: function(event, ui) { alert(this); }
          });

(2)常見參數

addClasses: [類型]Boolean(布爾值) [默認值]true
是否給draggable元素增長 ui-draggable這個css的class
axis: [類型]String [支持] ‘x’, ‘y’, false
控制元素 只能沿 X軸|Y軸 移動
containment:[類型]選擇器, 元素, 字符串, 數組
只能在選擇器約束的元素內拖動
delay:[類型]整數, 單位是毫秒
可拖動控件從鼠標左鍵按下開始, 到拖動效果產生的延時
還有:distance,distance,handle,helper,opacity (詳見 4、)性能

    $('.selector').draggable({ 
            addClasses: true,
            axis: 'x',
            containment: 'parent',  //parent: 只能在父容器內拖動 
            delay: 500,
            opacity: 0.35,  //被拖到時的不透明度
   });

五、 droppable()函數的參數

(1)函數

activate:在容許的draggable對象開始拖動時觸發.
deactivate:在容許的draggable對象中止拖動時觸發.
over:在容許的draggable對象」通過」這個droppable對象時觸發
out:在容許的draggable對象離開 這個droppable對象時觸發
drop:在容許的draggable對象填充進這個droppable對象時觸發.學習

       $('.selector').droppable({  
                activate: function(event, ui) { ... },
                deactivate: function(event, ui) { ... },
                over: function(event, ui) { ... },
                out: function(event, ui) { ... },
                drop: function(event, ui) { ... }  
       });

(2)常見參數

accept :[類型]Selector, Function [默認值]‘*’
容許被放下來的元素.
hoverClass :[類型]String [默認值]false
一個被容許的draggable對象懸停在droppable對象上時添加的class

還有:activeClass,greedy,scope,tolerance (詳見 5、)

            $('.selector').droppable({ 
                   accept: '#someid',
                   hoverClass: 'drophover'
            });

3、其餘相關文章

本文已經同步至個人我的博客站點:
jquery ui(二)拖拽 draggable和droppable ( http://ifxoxo.com/jquery-ui-draggable.html )

若是想查看其它jquery ui的文章,能夠點擊如下連接到我的博客查看

一、jquery ui(一)簡介 ( http://ifxoxo.com/jquery-ui-1.html )
二、jquery ui(二)拖拽 draggable和droppable ( http://ifxoxo.com/jquery-ui-draggable.html )
三、jquery ui(三)彈出窗口 dialog ( http://ifxoxo.com/jquery-ui-dialog.html )
四、jquery ui(四)進度條 progressbar ( http://ifxoxo.com/jquery-ui-prodressbar.html )
五、jquery ui(五)日期選擇器 datepicker ( http://ifxoxo.com/jquery-ui-datepicker.html )
六、jquery ui(六)拖動排序 sortable ( http://ifxoxo.com/jquery-ui-sortable.html )

4、drappable的超級詳細參數

一、回調函數

有start, stop, drag等事件,這些函數都接受兩個參數:event和ui。
event: 瀏覽器原生的事件 ; ui: 一個JQuery的ui對象。
其中ui 有如下屬性:
a) ui.helper: 正在拖動的元素的JQuery包裝對象, ui.helper.context能夠獲取到原生的DOM元素.
b) ui.position: ui.helper(也就是咱們要拖動的元素)相對於父元素(包含本身的元素, 若是是頂層, 對應body)的偏移, 值是一個對象{top, left}—-也就是能夠用ui.position.top獲取到該元素與父元素的top當前偏移
c) ui.offset: 與ui.position贊成, 這裏表示的是和瀏覽器內容區域左上邊界的偏移(注意, 是內容區域, 而不是html的body區域. html的body在默認狀況下, 各類瀏覽器中都會相對offset有偏移的.)
(1) start: 拖動開始, 指鼠標按下, 開始移動.
(2) drag: 拖動過程當中鼠標移動.
(3) stop: 拖動結束.
[代碼示例]
初始化時設置事件.
$(‘.selector’).draggable({
start: function(event, ui){ alert(this); },
drag: function(event, ui) { alert(this); },
stop: function(event, ui) { alert(this); }
});

二、經常使用參數(選項)

(1)addClasses

[類型]Boolean(布爾值)
[默認值]true
[產生影響]
用來設置是否給draggable元素經過ui-draggable樣式才裝飾它. 主要爲了在經過.draggable()初始化不少(成百個)元素的時候優化性能考慮, 可是, 這個選項的設置, 不會影響ui-draggable-dragging樣式改變拖動過程樣式.
true表示ui-draggable樣式被添加到該元素.
false表示ui-draggable樣式不被添加到該元素.
[代碼示例]draggable其餘選項的初始化,
$(‘.selector’).draggable({ addClasses: false });
將.selector選擇器選中的元素渲染成爲一個可拖動控件, 不爲其添加ui-draggable樣式

(2)appendTo:

[類型]Element, Selector(HTML元素對象或選擇器)
[默認值]‘parent’ 父元素
[產生影響]
用來指定控件在拖動過程當中ui.helper的容器, 默認狀況下, ui.helper使用和初始定義的draggable相同的容器, 也就是其父元素.
[代碼示例]
$(‘.selector’).draggable({ appendTo: ‘body’ });

(3)axis:

[類型]String, Boolean(可取的值有’x', ‘y’, false)
‘x’: 只能水平拖動
‘y’: 只能垂直拖動
false: 既能夠水平, 也能夠垂直拖動.
[默認值]false, 不限制拖動的方向
[產生影響]
約束拖動過程當中的取向.
[代碼示例]
$(‘.selector’).draggable({ axis: ‘x’ });

(4)containment:

[類型]選擇器, 元素, 字符串, 數組.
選擇器: 只能在選擇器約束的元素內拖動
元素: 只能在給定的元素內拖動
字符串:
parent: 只能在父容器內拖動
document: 在當前html文檔的document下可拖動, 超出瀏覽器窗口範圍時, 自動出現滾動條
widow: 只能在當前瀏覽器窗口的內容區域拖動, 拖動超出當前窗口範圍, 不會致使出現滾動條…
數組: [x1, y1, x2, y2]以[開始水平座標, 開始垂直座標, 結束水平座標, 結束垂直座標]的方式劃定一個區域, 只能在此區域內拖動. 這種方式指定時, 值是相對當前瀏覽器窗口內容區域左上角的偏移值.
false: 不限制拖動的活動範圍
[默認值]false
[產生影響]
影響指定可拖動控件的活動區域.
[代碼示例]
$(‘.selector’).draggable({ containment: ‘parent’ });
$(‘.selector’).draggable({ containment: ‘#demo-frame’ });

(5)cursor:

[類型]字符串.
[默認值]‘auto’
[產生影響]
影響指定可拖動控件在拖動過程當中的鼠標樣式, 該樣式設定以後, 須要控件的原始元素支持指定的cursor樣式, 若是指定的值原始元素不支持, 則使用原始元素默認的cursor樣式.
[代碼示例]
$(‘.selector’).draggable({ cursor: ‘crosshair’ });

(6)cursorAt:

[類型]對象
經過設置對象的top, left, right, bottom的屬性值中的一個或兩個來肯定位置.
[默認值]false
[產生影響]
在拖動控件的過程當中, 鼠標在控件上顯示的位置, 值爲false(默認)時, 從哪裏點擊開始拖動, 鼠標位置就在哪裏, 若是設置了, 就會在一個相對控件自身左上角偏移位置處, 好比: .
[代碼示例]
$(‘.selector’).draggable(‘option’, ‘cursorAt’, {left: 8, top: 8});
那麼拖動過程當中, 鼠標就會在自身的左上角向下向右各偏移8像素處

(7)delay:

[類型]整數, 單位是毫秒
[默認值]0
[產生影響]
可拖動控件從鼠標左鍵按下開始, 到拖動效果產生的延時. 該選項能夠被用來阻止一些不指望的點擊帶來的無效拖動. 具體效果是: 一次拖動, 從鼠標左鍵按下, 到delay指定的時間, 若是鼠標左鍵尚未鬆開, 那麼就認爲此次拖動有效, 不然, 認爲此次拖動無效.
[代碼示例]
$(‘.selector’).draggable({ delay: 500 });

(8)distance:

[類型]整數, 單位是像素
[默認值]1
[產生影響]
可拖動控件從鼠標左鍵按下開始, 到拖動效果產生的時鼠標必須產生的位移. 該選項能夠被用來阻止一些不指望的點擊帶來的無效拖動. 具體效果是: 一次拖動, 從鼠標左鍵按下, 只有當鼠標產生的位移達到distance指定的值時, 才認爲是有效的拖動.
[代碼示例]
$(‘.selector’).draggable({ distance: 30 });

(9)grid:

[類型]數組[x, y], x表明水平大小, y表明垂直大小, 單位是像素
[默認值]false
[產生影響]
可拖動控件拖動時採用grid的方式拖動, 也就是說拖動過程當中的單位是guid選項指定的數組描述的格子那麼大.
[代碼示例]
$(‘.selector’).draggable({ grid: [50, 20] });

(10)handle:

[類型]選擇器或元素
[默認值]false
[產生影響]
指定觸發拖動的元素. 用法: 將一個id=window的div設置爲可拖動控件, 設置它的handle是該div中的一個id=title的span, 那麼, 就只有在id=title的span上點擊拖動纔是有效的. 注意: 該元素必定要是可拖動控件的子元素.
[代碼示例]
$(‘.selector’).draggable({ handle: ‘h2′ });

(11)helper:

[類型]字符串或函數
字符串取值:
‘original’: 可拖動控件自己移動
‘clone’: 將可拖動控件自身克隆一個移動, 自身在原始位置不變
函數則必須返回一個DOM元素: 以函數返回的DOM元素移動展示拖動的過程.
[默認值]‘original’
[產生影響]
拖動過程當中幫助用戶知道當前拖動位置的元素.
[代碼示例]
$(‘.selector’).draggable({ helper: ‘clone’ });
helper: function(event){
return $( 「

I’m a custom helper

」 );
}

(12)opacity:

[類型]浮點數值
[默認值]false
[產生影響]
拖動過程當中helper(拖動時跟隨鼠標移動的控件)的不透明度.
[代碼示例]
$(‘.selector’).draggable({ opacity: 0.35 });

(13)revert:

[類型]Boolean, 字符串
true: 每次拖動中止以後, 元素自動回到原始位置
‘invalid’: 除非是一個droppable而且被drop(放)成功了, 纔不將元素返回到原始位置.
‘valid’: 除invalid以外的其餘狀況.
[默認值]false
[產生影響]
影響一次拖動以後是否迴歸到原始位置.
[代碼示例]
$(‘.selector’).draggable({ revert: true });

(14)revertDuration:

[類型]整數
[默認值]500
[產生影響]
revert(迴歸到原始位置)整個過程須要的時間, 單位是毫秒. 若是設置revert選項設置爲false, 則忽略此屬性.
[代碼示例]
$(‘.selector’).draggable({ revertDuration: 1000 });

(15)scope:

[類型]字符串
[默認值]‘default’
[產生影響]
在多個draggable和droppable對象的狀況下,爲了防止混亂,用來和droppable的對象進行分組。
只有處在同一個分組裏,droppable纔會接受。
該選項描述一個範圍, 和droppable的同名選項結合使用, droppable的accept選項用來設置能夠接受的draggable控件, 同時, 可接受的drggable控件受scope選項約束, 必須是同一個scope中的draggable和droppable才能夠互相拖放.
例如:
$(‘#draggable_a’).draggable({scope: ‘a’});
$(‘#draggable_b’).draggable({scope: ‘b’});
$(‘#droppable_a’).droppable({scope: ‘a’});
$(‘#droppable_b’).droppable({scope: ‘b’});
droppable控件的accept選項默認是’*', 看起來數draggable_a, draggable_b能夠自由的放入到droppable_a和droppable_b中, 可是, 因爲scope的約束, draggable_a只能放入到droppable_a, draggable_b只能髮乳到droppable_b中.
注意: 這個選項就和變量的名稱空間的意義相似. 默認值是’default’, 說明若是不指定, 你們都仍是有scope的, 名字是default而已.
[代碼示例]
$(‘.selector’).draggable({ scope: ‘tasks’ });

(16)scroll:

[類型]Boolean
[默認值]true
[產生影響]
若是設置爲true, 在拖動過程當中超出可拖動控件容器的時候, 容器自動增長滾動條
[代碼示例]
$(‘.selector’).draggable({ scroll: false });

(17)scrollSensitivity:

[類型]整數值
[默認值]20
[產生影響]
滾動條的敏感度.
下面所屬的鼠標指針是指在draggable控件移動過程當中, 鼠標所處位置.
鼠標指針和與draggable控件所在容器的邊距離爲多少的時候, 滾動條開始滾動.
[代碼示例]
$(‘.selector’).draggable({ scrollSensitivity: 40 });

(18)scrollSpeed:

[類型]整數值
[默認值]20
[產生影響]
因爲scrollSensitivity致使的滾動發生時, 滾動條一次滾動多少像素值.
[代碼示例]
$(‘.selector’).draggable({ scrollSpeed: 40 });

(19)snap

:
[類型]Boolean, 選擇器
[默認值]false
[產生影響]
吸附功能, 設置爲true等價與設置選擇器.ui-draggable, 具體效果是在選擇器指定的全部元素上, 當前的draggable控件均可以實現吸附功能, 吸附就是拖動過程當中, 靠近可是尚未捱上目標組件是, 自動的將正在拖動的組件吸過去.
[代碼示例]
$(‘.selector’).draggable({ snap: true });

(20)snapMode:

[類型]字符串, 可選值以下
‘inner’: 在指定的元素內部能夠吸附
‘outer’: 在指定元素外部能夠吸附
‘both’: 裏面外面均可以吸附.
[默認值]‘both’
[產生影響]
設定吸附時候的模式.
[代碼示例]
$(‘.selector’).draggable({ snapMode: ‘outer’ });

(21)snapTolerance:

[類型]整數
[默認值]20
[產生影響]
設定離目標對象的邊多少像素的時候, 進行吸附.
[代碼示例]
$(‘.selector’).draggable({ snap: true });

(22)stack:

[類型]對象{group: ‘.selector’, min: 50}
[默認值]false
[產生影響]
一次初始化一組draggable控件的時候, 將其中的一些draggable控件以給定選擇器選擇, 做爲一組, 這時, 這一組draggable控件就能夠實現當前被拖動的始終在最前效果, min用來指定這一組的z-index值的最小值.
[代碼示例]
$(‘.selector’).draggable({ stack: { group: ‘products’, min: 50 } });

(23)zIndex:

[類型]整數
[默認值]false
[產生影響]
拖動時的helper(跟隨鼠標移動的控件)的z-index值. z-index就是css中的層疊層數, 數值越大, 越在上層.
[代碼示例]
$(‘.selector’).draggable({ zIndex: 2700 });

5、droppable的超級詳細參數說明

一、事件

(1)activate

[產生影響]
這個事件會在任何容許的draggable對象開始拖動時觸發.
它能夠用來在你想讓droppable對象在能夠被填充的時」亮起來」的時候.
[代碼示例]
$(‘.selector’).droppable({ activate: function(event, ui) { … } });

(2)deactivate

[產生影響]
此事件會在任何容許的draggable對象中止拖動時觸發.
[代碼示例]
$(‘.selector’).droppable({ deactivate: function(event, ui) { … } });

(3)over

[產生影響]
此事件會在一個容許的draggable對象」通過」(根據tolerance參數的定義判斷)這個droppable對象時觸發.
[代碼示例]
$(‘.selector’).droppable({ over: function(event, ui) { … } });

(4)out

[產生影響]
會在一個容許的draggable對象離開(根據tolerance參數的定義判斷)這個droppable對象時觸發.
[代碼示例]
$(‘.selector’).droppable({ out: function(event, ui) { … } });

(5)drop

[產生影響]
這個事件會在一個容許的draggable對象填充進這個droppable對象時觸發.
回調函數中, $(this) 表示被填充的droppable對象. ui.draggable 表示draggable對象.
[代碼示例]
$(‘.selector’).droppable({ drop: function(event, ui) { … } });

二、參數(選項

(1)accept

[類型]Selector, Function
[默認值]‘*’
接受全部符合選擇器條件的draggable對象. 若是指定了一個函數, 該函數要求爲頁面上每一個draggable對象(符合函數第一個條件的對象)提供一個過濾器.若是要這些元素被dropable接受,該函數須要返回true.
[代碼示例]
使用指定的accept參數初始化一個droppable.
$(‘.selector’).droppable({ accept: ‘.special’ });

(2)activeClass

[類型]String
[默認值]false
[產生影響]
若是指定了該參數,在被容許的draggable對象填充時,droppable會被添加上指定的樣式.
[代碼示例]
使用指定的activeClass參數初始化一個droppable.
$(‘.selector’).droppable({ activeClass: ‘.ui-state-highlight’ });

(3)addClasses

[類型]Boolean
[默認值]true
[產生影響]
若是設置爲false, 能夠防止ui-droppable類在進行時添加. 這可能會使在初始化數百個元素執行.droppable()時使性能獲得理想的優化.
[代碼示例]
使用指定的addClasses參數初始化一個droppable.
$(‘.selector’).droppable({ addClasses: false });

(4)greedy

[類型]Boolean
[默認值]false
[產生影響]
若是設置爲true,將在嵌套的droppable對象中阻止事件的傳播.(阻止事件向上冒泡)
[代碼示例]
使用指定的greedy參數初始化一個droppable.
$(‘.selector’).droppable({ greedy: true });

(5)hoverClass

[類型]String
[默認值]false
[產生影響]
若是設置了該參數,將在一個被容許的draggable對象懸停在droppable對象上時向droppable對象添加一個指定的樣式.
[代碼示例]
使用指定的hoverClass參數初始化一個droppable.
$(‘.selector’).droppable({ hoverClass: ‘drophover’ });

(6)scope

[類型]String
[默認值]‘default’
[產生影響]
用來設置draggle對象和droppable對象的組, 除了droppable中的accept屬性指定的元素外,和droppable對象相同組的draggable對象也被容許添加到droppable對象中.
[代碼示例]
使用指定的scope參數初始化一個droppable.
$(‘.selector’).droppable({ scope: ‘tasks’ });

(7)tolerance

[類型]String容許使用的值: ‘fit’, ‘intersect’, ‘pointer’, ‘touch’.fit: draggable 徹底重疊到droppableintersect: draggable 和droppable至少重疊50%pointer: 鼠標重疊到droppabletouch: draggable和droppable的任意重疊[默認值]‘intersect’[產生影響]指定使用那種模式來測試一個draggable」通過」一個droppable對象.[代碼示例]使用指定的tolerance參數初始化一個droppable.$(‘.selector’).droppable({ tolerance: ‘fit’ });

相關文章
相關標籤/搜索