十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
本文为大家分享了jquery拖拽自动排序插件,供大家参考,具体内容如下

让客户满意是我们工作的目标,不断超越客户的期望值来自于我们对这个行业的热爱。我们立志把好的技术通过有效、简单的方式提供给客户,将通过不懈努力成为客户在信息化领域值得信任、有价值的长期合作伙伴,公司提供的服务项目有:国际域名空间、网络空间、营销软件、网站建设、辽源网站维护、网站推广。
该插件并不是原生js写的,是基于jquery的,想看原生的话,请绕道而行。
html:
Document
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'+ data[i]+'';
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() 踩得坑:
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"的元素才可以被拖动。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持创新互联。