js實現的dom元素拖動封裝外掛程式碼例項
在實際應用中經常會有對元素進行拖動的需求,下面就是一個對此功能的封裝程式碼。
需要的朋友可以做一下參考,程式碼如下:
[JavaScript] 純文字檢視 複製程式碼/** * 相容不同定位方式的通用拖動介面 * @param {Node} dragger 需要被拖動的元素 */ //必須告訴系統,哪些元素是可以進行互動,而哪些是不行 function canDrag(dragger) { var drag = bindEvent(dragger,'onmousedown',function(e){ //相容事件物件 e = e || event; //相容座標屬性 var pageX = e.clientX || e.pageX; var pageY = e.clientY || e.pageY; //相容樣式物件 var style = dragger.currentStyle || window.getComputedStyle(dragger,null); //當沒有設定left和top屬性時,IE下預設值為auto var offX = parseInt(style.left) || 0; var offY = parseInt(style.top) || 0; //獲取滑鼠相對於元素的間距 var offXL = pageX - offX; var offYL = pageY - offY; //為dragger增加onDrag屬性,用來儲存拖動事件 if (!dragger.onDrag) { //監聽拖動事件 dragger.onDrag = bindEvent(document,'onmousemove',function(e){ e = e || event; var x = e.clientX || e.pageX; var y = e.clientY || e.pageY //設定X座標 dragger.style.left = x - offXL + 'px'; //設定Y座標 dragger.style.top = y - offYL + 'px'; }); //監聽拖動結束事件 dragger.onDragEnd = bindEvent(document,'onmouseup',function(e){ //釋放前讀取事件物件 var x = e.clientX || e.pageX; var y = e.clientY || e.pageY //釋放拖動監聽和結束監聽 removeEvent(document, 'onmousemove', dragger.onDrag); removeEvent(document, 'onmouseup', dragger.onDragEnd); try { //刪除拖動時所用的屬性,相容FF使用 delete dragger.onDrag; delete dragger.onDragEnd; } catch (e) { //刪除拖動時所用的屬性,相容IE6使用 dragger.removeAttribute('onDrag'); dragger.removeAttribute('onDragEnd'); } }); } }); return function() { //返回一個可以取消拖動功能的函式引用 //釋放拖動監聽和結束監聽 removeEvent(document, 'onmousemove', dragger.onDrag); removeEvent(document, 'onmouseup', dragger.onDragEnd); try { //刪除拖動時所用的屬性,相容FF使用 delete dragger.onDrag; delete dragger.onDragEnd; } catch (e) { //刪除拖動時所用的屬性,相容IE6使用 dragger.removeAttribute('onDrag'); dragger.removeAttribute('onDragEnd'); } } }
相關文章
- react專案中實現元素的拖動和縮放例項React
- SVG拖動繪製矩形程式碼例項SVG
- dom操作程式碼例項
- HTML元素拖動JSHTMLJS
- JS 第三方工具封裝經典案例(canvas元素拖動)JS封裝Canvas
- JS21. 使用原生JS封裝一個公共的Alert外掛(HTML5: Shadow Dom)JS封裝HTML
- 用原生JS封裝外掛的方式有哪些?JS封裝
- js拖動調整元素寬度JS
- 原生js—ajax的封裝外掛.js—(對get和post做了相容)JS封裝
- jQuery利用name匹配元素程式碼例項jQuery
- Vue 封裝 loading 外掛Vue封裝
- JavaScript刪除元素節點程式碼例項JavaScript
- 原生js---ajax的封裝外掛.js---(對get和post做了兼JS封裝
- jQuery實現DOM元素事件動態繫結jQuery事件
- html實現簡單ListViews效果的例項程式碼HTMLView
- 封裝js獲取當前元素的弟弟元素節點封裝JS
- jQuery遍歷array陣列元素程式碼例項jQuery陣列
- JS 預編譯程式碼例項分析JS編譯
- vuejs實現新增tag標籤程式碼例項VueJS
- 例項程式碼分享Python實現Linux監控PythonLinux
- 程式碼自動生成外掛:
- jquery.idTabs.min.js選項卡程式碼例項jQueryJS
- 獲取倒數第幾個元素程式碼例項
- CSS匹配第一個li元素程式碼例項CSS
- 封裝avalonia指定元件允許拖動的工具類封裝元件
- 使用原生js實現選項卡功能例項教程JS
- vueusejs實現拖動VueJS
- MyCat分片:水平拆分例項解析和程式碼實現!
- JavaScript運動框架程式碼例項JavaScript框架
- kPagination-純js實現分頁外掛JS
- [前端外掛] js返回頂部 效果實現前端JS
- 用原生js進行封裝函式 實現 選項卡巢狀選項卡 功能JS封裝函式巢狀
- Flutter學習指南:封裝 API 外掛Flutter封裝API
- Vue外掛從封裝到釋出Vue封裝
- JavaScript拖動調整元素的尺寸JavaScript
- 手動實現HTML外掛BeautifyHTML
- Verilog外掛:補全模組例項模板
- 正則實現個位數補零程式碼例項
- 美化滾動條效果程式碼例項