jquery拖拽自动排序插件使用方法详解
程序员文章站
2023-11-30 09:04:16
本文为大家分享了jquery拖拽自动排序插件,供大家参考,具体内容如下
该插件并不是原生js写的,是基于jquery的,想看原生的话,请绕道而行。
html:...
本文为大家分享了jquery拖拽自动排序插件,供大家参考,具体内容如下
该插件并不是原生js写的,是基于jquery的,想看原生的话,请绕道而行。
html:
<!doctype html> <html lang="en"> <head> <meta charset="utf-8"> <title>document</title> <script type="text/javascript" src="jquery.js"></script> <script type="text/javascript" src="drag.js"></script> <style type="text/css"> div{ height: 200px; overflow-y: auto; } ul{ margin: 0; padding: 0; list-style: none; box-shadow: rgba(0, 0, 0, 0.2) 5px 5px 10px; display: inline-block; } .drag-item{ width: 100px; padding: 0 10px; line-height: 38px; cursor: move; } .draging{ background-color: #ccc !important; } .no-draging{ background-color: #fff !important; } </style> </head> <body> <ul class="drag-box"> </ul> </body> <script type="text/javascript"> new drag({ container: '.drag-box', data: ['应用1','应用2','应用3','应用4','应用5','应用6','应用7','应用8','应用9'] }); </script> </html>
js:
(function(win){ function drag(opts){ this.init(opts); }; drag.prototype = { constructor: drag, options: { container: '', data: [], //可以是数据,也可以是html标签 classname: 'item' }, //初始化 init: function(opts){ $.extend(this.options, opts); this.$el = $(this.get('container')); this._render(); this._bindevent(); }, get: function(key){ return this.options[key]; }, set: function(key, value){ this.options[key]=value; }, //渲染列表 _render: function(){ var me = this, lis = '', data = me.get('data') || []; for(var i=0,len=data.length;i<len;i++) lis+='<li class="drag-item" id="drag-item-'+i+'">'+ data[i]+'</li>'; me.$el.append(lis) .find('li').attr('draggable',true) .addclass(this.get('classname')); }, //绑定事件 _bindevent: function(){ var me = this, $lis = $('li', me.$el), events = ['dragstart', 'dragenter', 'dragover', 'drop', 'dragend']; $.each(events, function(index, item){ $lis.on(item, function(e){ me['_'+item+'handle'] && me['_'+item+'handle'](e, me); }); }) $lis.hover(function(){ $(this).css('background-color','#eee'); },function(){ $(this).css('background-color','#fff'); }); }, //开始拖动 _dragstarthandle: function(e){ var me = this,oe = e.originalevent; if(oe.datatransfer){ oe.datatransfer.setdata('text', ''); } me.$drag = $(e.currenttarget); $('li',me.$el).removeclass('item-hover'); me.$drag.addclass('draging').siblings().addclass('no-draging'); }, _dragenterhandle: function(e){ var me = this; me.$drop = $(e.currenttarget); if(me.timer){cleartimeout(me.timer)} //事件控制 me.timer = settimeout(function(){ if(me.$drag.attr('id') !== me.$drop.attr('id')){ me._createmask(); if(me.$drag.index()<me.$drop.index()) me.$drag.insertafter(me.$drop); else me.$drag.insertbefore(me.$drop); } }, 30); }, _dragoverhandle: function(e){ var oe = e.originalevent; e.preventdefault(); return false; }, _drophandle: function(e){ e.preventdefault(); e.stoppropagation(); return false; }, //拖动结束 _dragendhandle: function(e){ var me = this; me.$mask && me.$mask.remove(); settimeout(function(){ $('li', me.$el).removeclass('draging no-draging'); },30); }, //创建遮罩 _createmask: function(){ var me = this,$mask = me.$mask = $('<div class="drag-mask"></div>'); $mask.css({ position: 'absolute', width: me.$drop.outerwidth(),//new height: me.$drop.outerheight(),//new left: me.$drop.position().left, top: me.$drop.position().top+me.$el.scrolltop(),//new backgroundcolor: '#fff' }); $mask.on({ 'drop': me._drophandle, 'dragover': me._dragoverhandle }); this.$el.find('.drag-mask').remove(); this.$el.append($mask); } }; win.drag = drag; })(window);
踩得坑:
1、关于datatransfer, 事件对象e中是没有该属性的,要找该属性应该通过e.originalevent.datatransfer中去找。
2、兼容火狐浏览器。如果不这样操作,火狐下是无法运行的:
if(oe.datatransfer){ oe.datatransfer.setdata('text', ''); }
3、dragover事件每隔 350 毫秒会被触发一次。
4、dragstart、dragenter、dragend事件通过jquery绑定,事件处理函数中的this指向最外层对象,例如上面的new drag();dragover、drop事件通过jquery绑定,事件处理函数中的this指向被绑定的html标签。
5、jquery获取包括padding的宽度调用:$el.outerwidth()和$el.outerheight() 。
6、只有属性draggable="true"的元素才可以被拖动。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: MySQL优化之缓存优化(续)