本文为大家分享了jquery拖拽自动排序插件,供大家参考,具体内容如下
该插件并不是原生js写的,是基于jquery的,想看原生的话,请绕道而行。
html:
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Document</title> <script type="text/javascript" src="/UploadFiles/2021-04-02/jquery.js">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"的元素才可以被拖动。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。
更新日志
- 中国武警男声合唱团《辉煌之声1天路》[DTS-WAV分轨]
- 紫薇《旧曲新韵》[320K/MP3][175.29MB]
- 紫薇《旧曲新韵》[FLAC/分轨][550.18MB]
- 周深《反深代词》[先听版][320K/MP3][72.71MB]
- 李佳薇.2024-会发光的【黑籁音乐】【FLAC分轨】
- 后弦.2012-很有爱【天浩盛世】【WAV+CUE】
- 林俊吉.2012-将你惜命命【美华】【WAV+CUE】
- 晓雅《分享》DTS-WAV
- 黑鸭子2008-飞歌[首版][WAV+CUE]
- 黄乙玲1989-水泼落地难收回[日本天龙版][WAV+CUE]
- 周深《反深代词》[先听版][FLAC/分轨][310.97MB]
- 姜育恒1984《什么时候·串起又散落》台湾复刻版[WAV+CUE][1G]
- 那英《如今》引进版[WAV+CUE][1G]
- 蔡幸娟.1991-真的让我爱你吗【飞碟】【WAV+CUE】
- 群星.2024-好团圆电视剧原声带【TME】【FLAC分轨】