dragsort html拖拽排序
一、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拖拽排序的更多相关文章
- php接口实现拖拽排序功能
列表拖拽排序是一个很常见的功能,但是后端接口如何处理却是一个令人纠结的问题 如何实现才能达到效率最高呢 先分析一个场景,假如有一个页面有十条数据,所谓的拖拽就是在这十条数据来来回回的拖,但是每次拖动都 ...
- jQuery可拖拽排序列表jquery-sortable-lists
jquery-sortable-lists可以通过鼠标进行拖动排列树型菜单,可以定义某个列表元素是否拖动,拖动后回调,点击可以折叠树型结点,可以用来在后台模仿wordpress后台拖动菜单,实现多级菜 ...
- 使用knockout-sortable实现对自定义菜单的拖拽排序
在开始之前,照例,我们先看效果和功能实现. 关于自定义菜单的实现,这里就不多说了,需要了解的请访问:http://www.cnblogs.com/codelove/p/4838766.html 这里需 ...
- RecyclerView拖拽排序和滑动删除实现
效果图 如何实现 那么是如何实现的呢?主要就要使用到ItemTouchHelper ,ItemTouchHelper 一个帮助开发人员处理拖拽和滑动删除的实现类,它能够让你非常容易实现侧滑删除.拖拽的 ...
- ztree使用系列四(ztree实现同级拖拽排序并将排序结果保存数据库)
ztree这个系列的最后一篇,也是ztree功能强大的体现之中的一个--排序功能. ztree能够实现全部节点之间任意的拖拽排序功能.我这里依据须要实现了仅仅同意同级之间任意拖拽排序,事实上原理都一样 ...
- jquery sortTable拖拽排序
所有的事件回调函数都有两个参数:event和ui,浏览器自有event对象,和经过封装的ui对象 ui.helper - 表示sortable元素的JQuery对象,通常是当前元素的克隆对象 ...
- ListView列表拖拽排序
ListView列表拖拽排序能够參考Android源代码下的Music播放列表,他是能够拖拽的,源代码在[packages/apps/Music下的TouchInterceptor.java下]. 首 ...
- zTree的拖拽排序
ztree本身是可以支持拖拽的,但是却没有找到明确的支持拖拽的排序,也就是说,在拖拽过程中,需要自定义维护拖拽后的顺序并保存至后台. 在这样一个比较常规的需求情况下,网上也有朋友给出了一些解决方案,比 ...
- RecyclerViewItemTouchHelperDemo【使用ItemTouchHelper进行拖拽排序功能】
版权声明:本文为HaiyuKing原创文章,转载请注明出处! 前言 记录使用ItemTouchHelper对Recyclerview进行拖拽排序功能的实现. 效果图 代码分析 ItemTouchHel ...
随机推荐
- 探秘Tomcat——一个简易的Servlet容器
即便再简陋的服务器也是服务器,今天就来循着书本的第二章来看看如何实现一个servlet容器. 背景知识 既然说到servlet容器这个名词,我们首先要了解它到底是什么. servlet 相比你或多或少 ...
- java.util.ConcurrentModificationException异常处理
ConcurrentModificationException异常处理 ConcurrentModificationException异常是Iterator遍历ArrayList或者HashMap数组 ...
- 根据起止日期构建指定查询条件:第N周(yyyy-MM-dd/yyyy-MM-dd)
项目中有个查询模块中用到查询条件: 年和周. 以往我直接指定是第几周,后来测试反映如果直接选择周的话并不知道所选周代表的年月日,而无法最快查询数据,后更改查询条件如下: 指定一个起始年月,根据起始年月 ...
- Javascript常用正则表达式汇总
一.匹配数字和字符串 整数或者小数:^[0-9]+\.{0,1}[0-9]{0,2}$ 只能输入数字:"^[0-9]*$". 只能输入n位的数 字:"^\d{n}$&qu ...
- 大型网站提速关键技术(页面静态化,memcached,MySql优化)(二)
一:页面静态化 几个概念: 静态网址:(比如:http://localhost/abc.html) 特点:1.利用seo(search engine optimization) 搜索引擎优化;2:访问 ...
- MongoDB-基础-条件操作符
1.一些解释 less than : 比..少 lt greater than : 比..多 gt equals :相等 e ...
- roleManager与角色管理授权
总览地址 https://msdn.microsoft.com/zh-cn/library/9ab2fxh0.aspx 其中基本概述是第一篇:了解角色管理 来自 <https://msdn.mi ...
- win7中 SQL server 2005无法连接到服务器,错误码:18456
win7中 SQL server 2005无法连接到服务器,错误码:18456.. 数据库刚装完.我用Windows登陆 结果登陆不上去.. 选中SQL Server Management Stud ...
- order by用法
此文来源于CSDN中zxcvg的博文 1.ORDER BY 中关于NULL的处理 缺省处理,Oracle在Order by 时认为null是最大值,所以如果是ASC升序则排在最后,DESC降序则排在最 ...
- form表单提交和阻止
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...