zoukankan      html  css  js  c++  java
  • 用jquery的sortable做自定义网站模块

    标签:jquery,sortable,保存状态,排序 作者:田想兵

    点击本文实例演示

    今天呢,老话从谈一回,讲讲jquery组件里的sortable(排序)。还是希望大家多发表下自己的学习经验,也可当作以后的一种财富。

    重申下,本人能力有限,所以如果有地方说错了,请包涵,也希望与之交流,共同进步。

    其实在前年的这个时候,我就有用过这个sortable组件,那时候搞了个个人网站(可惜后来关了),首页就用到了这种拖拽的效果。当时也就从jquery的官方网站上抄了几句搞上去,后来发现用处不大,还挺慢。汗~~~以至于到今天早上也没搞清楚怎么样才能把排序后的结果保存起来,正好现在公司要做一个这样的功能,就又从新学习了下。欢迎志同道合者加入QQ技术群70210212或5678537,一起学习进步。

    首先,本文实例演示,在jquery的官方demo(http://jqueryui.com/demos/)上找到了相似的代码。我所要的叫就是portlets(http://jqueryui.com/demos/sortable/portlets.html)这种效果。就像igoogle首页那样的。冒似很简单,把要引用的js都加入后,然后几行代码就完事了。


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

    html代码省略...详情请查看http://www.lovewebgames.com/demo/sortable 或 http://jqueryui.com/demos/sortable/portlets.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) {
    }

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

    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

    改下开始的

    $(".column").sortable({
    connectWith: '.column',
    stop: saveLayout
    });
    stop是指拖拽结束后触发的事件.

    本文demo:http://www.lovewebgames.com/demo/sortable

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

    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))//把序列填加进容器
    }
    });
    })

     点击这里加入此群QQ群号:77813547

    好了,今天就这样吧,打字排版花了我一个小时了 ,还是很难看,没办法,本人很懒。

    本文demo:http://www.lovewebgames.com/demo/sortable

     关于删除项,由于长时间有人去群里问,所以也补充到实例去了,代码如下:

    $(".close").click(function(){
                    $(this).closest(".portlet").remove();
                    saveLayout();
                });
  • 相关阅读:
    来自lombok的注解(解决idea中的找不到get,set方法,找不到log的问题)
    IDL语言开发规范
    神经网络训练时出现nan错误
    Hadoop WordCount程序
    Hadoop2.4.1伪分布式安装
    Hadoop简介
    linux 安装tensorflow(gpu版本)
    高级映射,查询缓存和与spring整合
    用mybatis实现dao的编写或者实现mapper代理
    mybatis介绍与环境搭建
  • 原文地址:https://www.cnblogs.com/tianxiangbing/p/jquery_sortable.html
Copyright © 2011-2022 走看看