一、Jquery List DragSort
  对于有些页面,如首页的定制,需要进行动态的拖拽排序。由于自己实现比较困难,我们一般会使用一些js插件来实现。dragsort 就是帮助我们完成这一需求。通过dragsort我们可以很方便地对html页面上的素动态地推拽,进行排序。dragsort是一个jquery插件,我们使用起来非常方便。dragsort网站为:dragsort下载地址为:http://dragsort.codeplex.com/
下载dragsort之后,解压如下图所示,

  

  我们使用到的只有里面的jquery.dragsort-0.5.2.js这个文件,也可以使用压缩版的min.js。
二、实例
  1、使用
  将jquery.dragsort-0.5.2.js,与jquery-2.1.3.min.js拷贝到同一个文件夹,新建html页面。引入这两个js文件。注意jquery在dragsort上面引入。相关代码如下:

 <!DOCTYPE html>
 <html>
 <head>
     <title>拖拽示例</title>
     <meta charset="utf-8" />
     <style type="text/css">
         body { font-family:Arial; font-size:12pt; padding:20px; width:820px; margin:20px auto; border:solid 1px black; }
         h1 { font-size:16pt; }
         h2 { font-size:13pt; }
         ul { margin:0px; padding:0px; margin-left:20px; }
         #list1, #list2 { width:350px; list-style-type:none; margin:0px; }
         #list1 li, #list2 li { float:left; padding:5px; width:100px; height:100px; }
         #list1 div, #list2 div { width:90px; height:50px; border:solid 1px black; background-color:#E0E0E0; text-align:center; padding-top:40px; }
         #list2 { float:right; }
         .placeHolder div { background-color:white !important; border:dashed 1px gray !important; }
     </style>
     <script type="text/javascript" src="jquery-2.1.3.min.js"></script>
     <script type="text/javascript" src="jquery.dragsort-0.5.2.min.js"></script>
 </head>
 <body>

     <h1>示例</h1>
     <script type="text/javascript">
         $("ul:first").dragsort();
     </script>

     <h2>可以在两个分组直接进行拖拽</h2>

     <ul id="list2" class="draglist"  data-groupid="gid-2">
         <li data-id="10" data-groupid="gid-2"><div>10</div></li>
         <li data-id="11" data-groupid="gid-2"><div>11</div></li>
         <li data-id="12" data-groupid="gid-2"><div>12</div></li>
         <li data-id="13" data-groupid="gid-2"><div>13</div></li>
         <li data-id="14" data-groupid="gid-2"><div>14</div></li>
         <li data-id="15" data-groupid="gid-2"><div>15</div></li>
         <li data-id="16" data-groupid="gid-2"><div>16</div></li>
         <li data-id="17" data-groupid="gid-2"><div>17</div></li>
         <li data-id="18" data-groupid="gid-2"><div>18</div></li>
     </ul>
     <input name="sortorder" id ="gid-2" type="hidden" value="10,11,12,13,14,15,16,17,18" />

     <ul id="list1" class="draglist" data-groupid="gid-1">
         <li data-id="1" data-groupid="gid-1"><div>1</div></li>
         <li data-id="2" data-groupid="gid-1"><div>2</div></li>
         <li data-id="3" data-groupid="gid-1"><div>3</div></li>
         <li data-id="4" data-groupid="gid-1"><div>4</div></li>
         <li data-id="5" data-groupid="gid-1"><div>5</div></li>
         <li data-id="6" data-groupid="gid-1"><div>6</div></li>
         <li data-id="7" data-groupid="gid-1"><div>7</div></li>
         <li data-id="8" data-groupid="gid-1"><div>8</div></li>
         <li data-id="9" data-groupid="gid-1"><div>9</div></li>
     </ul>
     <input name="sortorder" id ="gid-1" type="hidden" value="1,2,3,4,5,6,7,8,9"/>
     <div style="clear:both;"></div>
 <script type="text/javascript">
     $(".draglist").dragsort({
     dragSelector: "li",
     dragBetween: true,
     dragEnd: saveOrder, //拖拽完成后回调函数
     placeHolderTemplate: "<li class='placeHolder'><div></div></li>" //拖动是阴影
 });

 function saveOrder() {
     var $this = $(this);
     var data = $this.parent().children().map(function() {
         return $this.attr("data-id");
     }).get();

     var currentid = $this.attr("data-id"); //组件id
     var oldgroupid = $this.attr("data-groupid"); //所属组id
     var groupid = $this.parent().attr("data-groupid"); //目标组id

     //跨组移动、移除旧组信息
     if (oldgroupid != groupid) {
         var oldgroup = $("#" + oldgroupid);
         var groupval = oldgroup.val().replace(currentid, "");
         oldgroup.val(groupval);
     }

     $("#" + groupid).val(data.join(",")); //添加所属组记录
     $this.attr("data-groupid", groupid); //改变所属组id
 };

 /**
  * 保存位置
  */
 function savePosition() {
     var inputs = $("input[name='sortorder']");
     var arr = new Array();
     //构造数据
     inputs.each(function() {
         var $this = $(this);
         arr.push($this.attr("id") + "-" + $this.val());
     });

     $.ajax({
         url: "${ctx}/test/position.json",
         type: "POST",
         data: { "tiles": arr },
         dataType: "json",
         success: function(data) {
             if (data.flag)
                 alert("保存成功");
             else
                 alert("保存失败");
         }
     });
 }
 </script>
 </body>
 </html>

  其中两个input的值为li的id(以","连接),id值的顺序标识当前分组li的排列顺序。跨组拖动的时候两个input中的值会随之改变。从而达到跨组移动的效果。需要保存的时候,直接使用ajax将两个input的值进行提交,后台解析数据保存到数据库即可。

  2、效果如下。

  示例下载:下载 。

dragsort html拖拽排序的更多相关文章

  1. jQuery可拖拽排序列表jquery-sortable-lists

    jquery-sortable-lists可以通过鼠标进行拖动排列树型菜单,可以定义某个列表元素是否拖动,拖动后回调,点击可以折叠树型结点,可以用来在后台模仿wordpress后台拖动菜单,实现多级菜 ...

  2. 使用knockout-sortable实现对自定义菜单的拖拽排序

    在开始之前,照例,我们先看效果和功能实现. 关于自定义菜单的实现,这里就不多说了,需要了解的请访问:http://www.cnblogs.com/codelove/p/4838766.html 这里需 ...

  3. RecyclerView拖拽排序和滑动删除实现

    效果图 如何实现 那么是如何实现的呢?主要就要使用到ItemTouchHelper ,ItemTouchHelper 一个帮助开发人员处理拖拽和滑动删除的实现类,它能够让你非常容易实现侧滑删除.拖拽的 ...

  4. ztree使用系列四(ztree实现同级拖拽排序并将排序结果保存数据库)

    ztree这个系列的最后一篇,也是ztree功能强大的体现之中的一个--排序功能. ztree能够实现全部节点之间任意的拖拽排序功能.我这里依据须要实现了仅仅同意同级之间任意拖拽排序,事实上原理都一样 ...

  5. jquery sortTable拖拽排序

    所有的事件回调函数都有两个参数:event和ui,浏览器自有event对象,和经过封装的ui对象   ui.helper - 表示sortable元素的JQuery对象,通常是当前元素的克隆对象   ...

  6. ListView列表拖拽排序

    ListView列表拖拽排序能够參考Android源代码下的Music播放列表,他是能够拖拽的,源代码在[packages/apps/Music下的TouchInterceptor.java下]. 首 ...

  7. zTree的拖拽排序

    ztree本身是可以支持拖拽的,但是却没有找到明确的支持拖拽的排序,也就是说,在拖拽过程中,需要自定义维护拖拽后的顺序并保存至后台. 在这样一个比较常规的需求情况下,网上也有朋友给出了一些解决方案,比 ...

  8. ListBox实现拖拽排序功能

    1.拖拽需要实现的事件包括: PreviewMouseLeftButtonDown LBoxSort_OnDrop 具体实现如下: private void LBoxSort_OnPreviewMou ...

  9. 关于jqueryUI里的拖拽排序

    主要参考http://jsfiddle.net/KyleMit/Geupm/2/  (这个站需要FQ才能看到效果) 其实是jqueryUI官方购物车拖拽添加例子的增强版,就是在拖拽的时候增加了排序 这 ...

随机推荐

  1. .NET 学习书籍推荐

    时间过得好快啊,转眼三月过了1周多了,今天把看书的目录记录下,方便初学者 最近由于项目需要研究下dotnet 技术,参考书籍如下: 1.深入理解C# 2.CLR via  C# 3.Framework ...

  2. linux添加环境变量(centos)

    1.查看当前环境变量 #echo $PATH 2.增加环境变量 #vi /etc/profile export PATH=/usr/path/bin:$PATH 3.生效 #source /etc/p ...

  3. 自定义CollectionViewLayout

    转自answer-huang的博客 原文出自:Custom Collection View Layouts    UICollectionView在iOS6中第一次被介绍,也是UIKit视图类中的一颗 ...

  4. JavaScript 32位整型无符号操作

    在 JavaScript 中,所有整数字变量默认都是有符号整数,这意味着什么呢? 有符号整数使用 31 位表示整数的数值,用第 32 位表示整数的符号,0 表示正数,1 表示负数. 数值范围从 -2^ ...

  5. 选择时区的命令tzselect

    选择时区的命令tzselect tzselectPlease identify a location so that time zone rules can be set correctly.Plea ...

  6. 无法找到脚本*.VBS的脚本引擎解决办法

    当你在运行一些基于VBS脚本语言的文件时,系统可能报错.这时候可能是你的VBS脚本服务在注册表中出错了,原因可能是卸载或安装一些代码不规范的程序引起的.这里给出无法找到脚本引擎"vbscri ...

  7. angular的注入实现

    angular需要对用户的传入函数进行静态分析,抽取当中的依赖,才能工作.因此用户的函数,包括控制器函数,工厂函数,服务函数与$watch回调都只是一个模板,用于取toString,真正运行的是编译后 ...

  8. 内容提供者 DocumentProvider Uri工具类

    Activity /**详见http://blog.csdn.net/coder_pig/article/details/47905881 Calendar Provider:日历提供者,就是针对针对 ...

  9. tomcat 配置SSL

    本教程使用 JDK 6 和 Tomcat 7,其他版本类似. 基本步骤: 使用 java 创建一个 keystore 文件 配置 Tomcat 以使用该 keystore 文件 测试 配置应用以便使用 ...

  10. 【Vue】详解Vue生命周期

    Vue实例的生命周期全过程(图) (这里的红边圆角矩形内的都是对应的Vue实例的钩子函数) 在beforeCreate和created钩子函数间的生命周期 在beforeCreate和created之 ...