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 ...
随机推荐
- Cesium原理篇:7最长的一帧之Entity(下)
上一篇,我们介绍了当我们添加一个Entity时,通过Graphics封装其对应参数,通过EntityCollection.Add方法,将EntityCollection的Entity传递到DataSo ...
- 如何设置 Panorama 控件的只读 SelectedIndex 属性?
在 OnNavigatedTo() 方法中设置: panoramaControl.DefaultItem = panoramaControl.Items[indexToSet];
- IIS与ASP.NET管道
IIS 5.x与ASP.NET 我们先来看看IIS 5.x是如何处理基于ASP.NET资源(比如.aspx,.asmx等)请求的,整个过程基本上可以通过图1体现. IIS 5.x运行在进程InetIn ...
- 【原创】Java编译器对String的优化
首先看以下的代码: public static void main(String[] arge) { String str1 = new String("1234"); Strin ...
- Using Nuget in Visual Studio 2005 & 2008
NuGet is a Visual Studio extension that makes it easy to install and update third-party libraries an ...
- 为jQuery写插件
很多场合,我们都会调用jQuery的插件去完成某个功能,比如slider. 如下图,做一个div,通过“$( "#slider" ).slider();”的方式直接将div变成sl ...
- .Net 开源项目资源大全
伯乐在线已在 GitHub 上发起「DotNet 资源大全中文版」的整理.欢迎扩散.欢迎加入. https://github.com/jobbole/awesome-dotnet-cn (注:下面用 ...
- 查找html节点的方法
document.firstChild document.documentElement(兼容性较好) 查找body节点的方法 document.firstChild.lastChild docume ...
- linux系统下make & make install
make,make install都是典型的使用GNU的AUTOCONF和AUTOMAKE产生的程序的安装步骤. make是用来编译的,在命令行输入make命令之后,系统会在当前目录下搜索Makefi ...
- [示例] Firemonkey 不规则按钮实做
利用 Firemonkey 控件的组合及可塑性,可以做出千变万化的效果及功能,下面展示一个不规则按钮的实做: 效果图: 实做方法: 开一个新工程 Multi-Device Application 放一 ...