js對dom的拖動

2021-05-27 21:35:24 字數 1293 閱讀 1314

實現這個功能所需要的知識點不多,如下:

1、js中element.style.left

style.left返回的變數是個字串,是個可改變量

js中element.offsetleft

offsetleft返回的是個int型別,不可改變量(意思就是說,改這個變數是不會影響布局的)

2、js 中event.clientx

clientx 事件屬性返回當事件被觸發時滑鼠指標向對於瀏覽器頁面(或客戶區)的水平座標。

3、js中element.classname

改變樣式的類的方法

以上三點都是些比較熟的知識了,想說的是以下這點:

4、js中為物件新增事件監控

element.addeventlistener("event","fun","boolen");

event:表示事件

fun:指的是事件觸發後執行的函式

我發現個問題啊,這個問題我弄了好久都找不出很好的解決方法

我們來看個例子:(方便測試,我把**寫在乙個檔案裡面 )

drag.html

**很簡單,肯用一點點心看的話,都能看懂了

第一次拖拽很成功,按住滑鼠進行拖。第二次就不正常了,要想第二次正常,必須滑鼠點一下其他地方(就是非拖拽部分)

上面的滑鼠事件

「mousedown」是指按下滑鼠時觸發此事件,(上面觸發了beforedrag函式)

"mousemove"指滑鼠移動時觸發此事件,(上面觸發了ondrag函式)

"mouseup"指滑鼠按下後鬆開滑鼠時觸發此事件。(上面觸發了enddrag函式)

ps:網上查的滑鼠時間是"onmousedown",筆者實驗"onmousedown"沒有事件響應,"mousedowm"才正常

上面所說的問題,嘗試了很多實驗,考慮到了addeventlistener的順序問題,第三個引數true/false的事件流問題,還是沒有找到完美的解決方法

"mouseup"事件在第二次監控就失敗了,重新獲取焦點才正常(就是滑鼠點一下其他地方)

求解釋

dom結構拖動排序

通過class獲取元素 function getclass cls return ret 獲取屬性 function getstyle obj,attr function startmove obj,json,fun else var ispeed json attr icur 6 運動速度如果大於...

JS 拖動事件

by zhangxinxu welcome to visit my personal website zxx.drag v1.0 2010 03 23 元素的拖拽實現 var params 獲取相關css屬性 var getcss function o,key 拖拽的實現 var startdrag...

js拖動滑塊

在pc端可以用mousedown來觸發乙個滑塊滑動的效果,但在手機上,貌似無法識別這個事件,但手機上有touchstart事件,可以通過一系列 touch 事件來替代pc端的 mouse 事件。移動端觸屏滑動的效果其實就是輪播,在pc的頁面上很好實現,繫結click和mouseover等事件來完成。...