最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

jquery拖拽自动排序插件使用方法详解

来源:动视网 责编:小OO 时间:2020-11-27 22:03:04
文档

jquery拖拽自动排序插件使用方法详解

本文为大家分享了jquery拖拽自动排序插件,供大家参考,具体内容如下:该插件并不是原生js写的,是基于jquery的,想看原生的话,请绕道而行。html。<。important;} .no-draging{ background-color: #fff js。
推荐度:
导读本文为大家分享了jquery拖拽自动排序插件,供大家参考,具体内容如下:该插件并不是原生js写的,是基于jquery的,想看原生的话,请绕道而行。html。<。important;} .no-draging{ background-color: #fff js。


本文为大家分享了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"的元素才可以被拖动。

文档

jquery拖拽自动排序插件使用方法详解

本文为大家分享了jquery拖拽自动排序插件,供大家参考,具体内容如下:该插件并不是原生js写的,是基于jquery的,想看原生的话,请绕道而行。html。<。important;} .no-draging{ background-color: #fff js。
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top