jquery中的sortable排序之后的保存状态的解决方法

2016-02-19 13:54 126 1 收藏

下面图老师小编跟大家分享一个简单易学的jquery中的sortable排序之后的保存状态的解决方法教程,get新技能是需要行动的,喜欢的朋友赶紧收藏起来学习下吧!

【 tulaoshi.com - Web开发 】

当时也就从jquery的官方网站上抄了几句搞上去,后来发现用处不大,还挺慢。汗~~~以至于到今天早上也没搞清楚怎么样才能把排序后的结果保存起来,正好现在公司要做一个这样的功能,就又从新学习了下。
首先,在jquery的官方demo(http://jqueryui.com/demos/)上找到了相似的代码。我所要的叫就是portlets(http://jqueryui.com/demos/sortable/portlets.html)这种效果。就像igoogle首页那样的。冒似很简单,把要引用的js都加入后,然后几行代码就完事了。

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)

代码如下:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)


script type="text/javascript"
$(function() {
$(".column").sortable({
connectWith: '.column'
});
});
/script

html代码省略...详情请查看演示

写完这些之后,你就可以试着拖拽了。有没有觉得很有成就感?不错,小伙子,有前途。sortable 有许多的参数,详细的自己去官网上看吧!只说下这里的connectWith:'.column'是什么意思,它就是说,凡是class为column的,它都可以把一个column的portlet拖到另一个column里去。试试你就知道了。当然今天的重点并不是怎么样去拖拽它,而是拖拽之后刷新还保存着当时的顺序。

遇到点小困难了,不过那也得上啊,不然以后都被女孩子肯嫁给你!^_^ 于是乎我就开始google百度了。有人说用sortable的serialize方法可以得到一个ID数组,可惜,我确实没有得到。如果你做到了也请你tell me 一下;还有人说用toArray方法也可以得到ID数组.这次也确实得到了。不过非常令人讨厌的事发生了。

$('.column').sortable('toArray');

这样也只能得到第一个class是column里的ID数组.用each()? I tried, but not work;可能你能做到,也请你告诉我吧!所以只能转走其他方法了。或许你会说,这还不简单么,直接把整个网页的布局存起来不就OK了?哈哈,I also think so!通过iedeveloper调试工具发现,它们拖动之后发现了改变,变的不是样式,而是div的先后顺序。如果我把整个内容保存起来的话,似乎也行得通,不过量就有点大了,也不适于动态的内容。怎么办呢,于是我就想着只存它们的ID顺序不就O了吗?于是我又给它们每人一个ID了。

万事开头难,有了这个思路了之后,你是否已经厕所打开了呢?我先去下便下,谢谢开门,马上回来!

接下来就一步步按照这个思路来吧。首先是获取到所有的column.

$.each($(".column"), function(m) {}

再找每个column下的portlet;

$.each($(".column"), function(m) {
$.each($(this).children(".portlet"), function(d) {
}

接着就是把它们按自己的方式存起来。

代码如下:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)


function saveLayout(){
var list = "";
$.each($(".column"), function(m) {
list += $(this).attr('id') + ":";
$.each($(this).children(".portlet"), function(d) {
list += $(this).attr('id') + "@";
})
list += "|";
})
$.cookie("list", list)}

这里还用到了另一组件jquery.cookie

改下开始的

代码如下:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)


$(".column").sortable({
connectWith: '.column',
stop: saveLayout
});

stop是指拖拽结束后触发的事件.

最后就是按顺序读到容器里去,这里我就不多说了,只可意会,不能言传哈。贴代码吧:

代码如下:

(本文来源于图老师网站,更多请访问https://www.tulaoshi.com/webkaifa/)


var list = $.cookie("list"); //获取cookie里的list值
//alert(list)
var arrColumn = list.split('|');
$.each(arrColumn, function(m, n) {
var elemId = n.split(':')[0]; //容器ID
var arrRow = n.split(':')[1] ? n.split(':')[1].split('@') : ""; //单个序列ID
$.each(arrRow, function(m, n) {
if (n) {//排除空值
$("#" + elemId).append($("#sb" + n).attr('id', n))//把序列填加进容器
}
});
})

好了,今天就这样吧. 


来源:https://www.tulaoshi.com/n/20160219/1605576.html

延伸阅读
标签: 电脑入门
把在本机上预览很完美的用PowerPoint制作的会议报告拿到别的机器上放映解说声音太小!把音量调大后,背景音乐也跟着大起来,严重影响了效果。用软件将背景声音调小?当时没有相关软件,再说时间也不允许。还有几分钟会议就要开始了,怎么办?放弃背景音乐?会议的气氛可还要靠它来衬托呢。突然想到背景音乐为MIDI格式,解说词为WAV格式有了,两...
标签: Web开发
使用jquery 的ajax功能调用一个页面,却发现总是出现错误。 js代码如下 代码如下: $.ajax({ type: 'post', url: 'TestData.aspx', data: { language_type: 'cn'}, dataType: 'json', success: function (data) { alert('ok'); }, error: function (data) { alert('err'); }); } TestData.aspx代码如下,省略了后边一些代码 ...
标签: Web开发
很多朋友在使用Deamweaver8的时候都会遇到这样的情况:给当前编辑的文档链接了CSS文件,并对页面元素应用了定义的CSS样式,但在DW8中却看不到任何效果。如下图。 主要原因就是DW8新多出了一个“样式呈现工具栏”,该工具栏允许你轻易的为不同的媒体类型,例如屏幕、手持设备和打印输出进行设计。其他的支持媒体类型有投影设备, TT...
JTable的排序是一个让人头疼的问题,Sun没有为排序这个最常用的功能提供类。 但是近日翻看Sun官方java的tutorial,却发现其在文档中提供了这个类的实现,使用非常简单! 使用方法示例: 代码如下: TableSorter sorter = new TableSorter(new MyTableModel()); //ADDED THIS //JTable table = new JTable(new MyTableModel()); //OLD JTable ...
由于WPS体积小并不像office那样,包含所有功能,有些版本是根据用户需求而设计的,所以在使用过程中总会有那么几个功能无法使用。比如小编的WPS2013中就无法使用VBA,在使用中发现,它在开发工具中以黑色呈现,如果一定要用的话还需重新下载安装,由于在安装过程遇到了一些问题,因此在接下来的文章中把解决问题的经验与大家分享下。主要是利用...

经验教程

46

收藏

46
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部