`

jQuery实现拖动布局并将排序结果保存到数据库

阅读更多

最近的项目中涉及到了用户个性化定制首页的需求,用户要求可以随意拖动首页模块的位置,来实现个性化的布局。本文讲解如何使用jquery和PHP实现拖动布局并将拖动后的布局位置保存到数据库。

查看演示DEMO

很多网站的拖动布局的例子都是采用浏览器的COOKIE来记录用户拖动模块的位置,也就是说拖动后各模块的排序位置信息是记录在客户端的cookie里的。当用户清空客户端的cookie或浏览器的cookie过期后,再次访问页面时,发现布局又还原成最初的状态。这种cookie记录的方式使用简单,但不适合像个人中心、管理系统主页的要求。

本例实现的效果:

  • 通过拖动随意布局页面模块。
  • 记录拖动后模块的位置,并记录到数据库中。
  • 页面永久性布局,用任意浏览器在任意时候打开,页面布局不变。(除非用户再次更改模块的排序,跟cookie没有关系)。

原理

采用jquery uisorttable拖动排序插件实现拖动效果。

将拖动后的模块的位置通过ajax传给服务端PHP程序。

PHP程序处理位置信息后,更新数据库中相应的字段内容。

XHTML

<div id="loader"></div> 
<div id="module_list"> 
   <input type="hidden" id="orderlist" /> 
   <div class="modules" title="1"> 
      <h3 class="m_title">Module:1</h3> 
      <p>1</p> 
   </div> 
   ... 
</div> 

DIV#loader用于显示提示信息,如loading...,#orderlist是一个隐藏域,用于记录模块的排序值。“...”表示循环了n个DIV.modules,具体生成的代码在后面会讲到。

CSS

#module_list{margin-left:4px.modules{float:leftwidth:200pxheight:140pxmargin:10pxborder:1px solid #acc6e9; 
 background:#e8f5fe.m_title{height:24pxline-height:24pxbackground:#afc6e9#loader{height:24pxtext-align:center

简单,关键是要给.modules一个想左浮动的样式float:left。

jQuery

$(function(){ 
    $(".m_title").bind('mouseover',function(){ 
        $(this).css("cursor","move") 
    }); 
     
    var $show = $("#loader");  
    var $orderlist = $("#orderlist"); 
    var $list = $("#module_list"); 
     
    $list.sortable({ 
        opacity: 0.6//设置拖动时候的透明度 
        revert: true, //缓冲效果 
        cursor: 'move'//拖动的时候鼠标样式 
        handle: '.m_title',  //可以拖动的部位,模块的标题部分 
        update: function(){ 
             var new_order = []; 
             $list.children(".modules").each(function() { 
                new_order.push(this.title); 
             }); 
             var newid = new_order.join(','); 
             var oldid = $orderlist.val(); 
             $.ajax({ 
                type: "post", 
                url: "update.php"//服务端处理程序 
                data: { id: newid, order: oldid },   //id:新的排列对应的ID,order:原排列顺序 
                beforeSend: function() { 
                     $show.html("<img src='load.gif' /> 正在更新"); 
                }, 
                success: function(msg) { 
                     //alert(msg); 
                     $show.html(""); 
                } 
             }); 
        } 
    }); 
}); 

拖动排序的动作都写在$list.sortable({...})里面,参数设置和方法请看代码的注释。juery ui的sortable插件提供了很多方法和参数配置,详情请查看http://jqueryui.com/demos/sortable

拖动完成要执行一个update方法,该方法需要将拖动后排序的位置通过ajax提交给后台处理。

var new_order = []; 
$list.children(".modules").each(function() { 
     new_order.push(this.title); 
}); 
var newid = new_order.join(','); 
var oldid = $orderlist.val(); 

说明:循环每个模块.modules,获取拖动排序后每个模块的属性title值,将值通过逗号连接成一个字符串。原来的未拖动之前的排序值从隐藏域orderlist中获取。

获取排序值后,就是通过ajax和后台程序交互了。

PHP

update.php接收前端ajax通过POST提交过来的两个参数,及排序前的值和排序后的值,将这连个值进行对比,如果不相等,则更新数据库中的排序字段,完成了拖动排序后的及时保存。

include_once("connect.php");//连接数据库 
$order = $_POST['order']; 
$itemid = trim($_POST['id']); 
if (!empty ($itemid)) { 
    if ($order != $itemid) { 
        $query = mysql_query("update sortlist set sort='$itemid' where id=1"); 
        if ($query) { 
            echo $itemid; 
        } else { 
            echo "none"; 
        } 
    } 
} 

首页index.php

再回到展示布局的首页index.php。index.php通过连接数据库读取模块的排序信息,并将各模块显示出来。

首先别忘了加载jquery库和jquery ui的sortable拖动排序插件。

<script type="text/javascript" src="js/jquery.js"></script> 
<script type="text/javascript" src="js/jquery-ui.min.js"></script> 

读取数据库的排序字段值。

include_once("connect.php"); 
 
$query=mysql_query("select * from sortlist where id=1"); 
if($rs=mysql_fetch_array($query)){ 
       $sort=$rs['sort']; 
} 
$sort_arr=explode(",",$sort); 
$len=count($sort_arr); 

循环显示各模块。

<div id="loader"></div> 
<div id="module_list"> 
  <input type="hidden" id="orderlist" value="<?php echo $sort;?>" /> 
  <?php  
     for($i=0;$i<$len;$i++){ 
  ?> 
  <div class="modules" title="<?php echo $sort_arr[$i]; ?>"> 
      <h3 class="m_title">Module:<?php echo $sort_arr[$i]; ?></h3> 
      <p><?php echo $sort_arr[$i]; ?></p> 
  </div> 
  <?php } ?> 
</div> 

诚然,真正的拖动排序结果的保存都跟每个用户信息相关联,所以数据库的结构设计方面大家可以自行解决,尽情发挥吧。

声明:本文为原创文章,helloweba.com和作者拥有版权,如需转载,请注明来源于helloweba.com并保留原文链接,否则视为侵权。
分享到:
评论

相关推荐

    jQuery可水平垂直自由拖拽代码.zip

    在JavaScript的世界里,jQuery是一个非常...通过研究和学习这些文件,你可以更好地理解如何结合jQuery和drag.js实现拖拽特效,并将其应用到自己的项目中。这个压缩包是一个很好的起点,帮助你掌握这一重要的前端技术。

    Asp.net+JQuery拖拽布局并保存至数据库

    标题 "Asp.net+JQuery拖拽布局并保存至数据库" 涉及的技术领域主要集中在Web开发,尤其是客户端交互和后端数据处理。这里我们将深入探讨如何利用JQuery实现拖拽布局,以及如何将这种布局信息存储到Asp.net应用程序的...

    基于jquery的拖拽交换和拖拽排序组件

    本篇文章将深入探讨基于jQuery的拖拽交换与拖拽排序组件,这是一种提升用户界面交互性的重要技术,尤其适用于构建动态列表和可自定义布局的应用。 拖拽交换和拖拽排序功能在网页应用中非常常见,例如在日程管理、...

    jQuery可拖动网格布局排列代码.zip

    "jQuery可拖动网格布局排列代码"就是一款利用jQuery库结合gridster.js插件实现的高效解决方案,旨在提供一个可自定义、可拖动的网格布局系统。这篇文章将深入探讨这一技术的实现原理和应用。 首先,jQuery作为一款...

    jQuery拖动布局其结果保存到数据库

    在本文中,我们将探讨如何使用jQuery实现拖动布局功能,并将用户自定义的布局顺序保存到数据库中。这个功能在很多个性化定制的场景下非常有用,例如用户可以在个人中心或管理系统的首页上自由调整模块的位置,以满足...

    Jquery Sortable实现div拖动排序效果

    本篇文章将深入探讨如何使用 jQuery Sortable 实现div的拖动排序效果。 首先,你需要在项目中引入 jQuery 和 jQuery UI 的库。jQuery 是一个广泛使用的JavaScript库,而 jQuery UI 提供了包括Sortable在内的多种...

    jQuery ui drag插件实现浮动div拖动排列布局代码

    本篇文章将深入讲解如何使用jQuery UI Drag插件来创建可拖动的浮动div,并将其应用于布局排列,以及如何将排序结果保存到数据库。 **1. jQuery UI Drag插件介绍** jQuery UI是基于jQuery库的一个扩展,它提供了...

    jquery实现拖拽排序插件.zip

    5. **数据同步**:拖拽排序完成后,通常需要将新的顺序同步到后台数据库或保存在本地存储中,以便在下次访问时保持用户的排序设置。 通过这个插件,开发者可以快速实现一个交互性强、用户体验良好的拖拽排序功能,...

    jquery实现的div拖动排序插件jquery.sortable源码.zip

    3. 排序更新:在mouseup事件中,插件会记录当前的元素顺序,并触发特殊的sort事件,供开发者获取新的排序信息,通常用于更新数据库或保存用户设置。 三、源码解析 在解压的文件中,"使用须知.txt"可能包含了一些...

    jQuery网格拖动图片排序插件特效源码.zip

    本篇文章将详细解析"jQuery网格拖动图片排序插件特效源码",帮助开发者理解其工作原理,并提供实践指导。 首先,我们需要了解jQuery的基本概念。jQuery是一个快速、简洁的JavaScript库,它简化了HTML文档遍历、事件...

    php+mysql+js拖拽div实例

    本实例将介绍如何使用PHP、MySQL和JavaScript实现一个拖拽Div的动态效果,并将其数据保存到数据库中,便于后续处理和展示。 **一、JavaScript拖拽功能实现** 1. **事件监听**:首先,我们需要在HTML中为要拖动的...

    jquery图片拖拽排序.rar

    最后,为了保存用户的排序,可以通过Ajax将新的排序信息发送到服务器端,更新数据库中的记录。同时,为了提供更好的用户体验,可以实时更新页面上图片的顺序,而不仅仅是拖放结束后。 以上就是使用jQuery实现图片...

    jQuery鼠标上下拖动div排序代码.zip

    `update`回调函数会在排序发生改变后被调用,提供了一个接口来处理排序更新的结果,例如将新的顺序保存到后台数据库。 总的来说,"jQuery鼠标上下拖动div排序代码.zip"提供了一套完整的实现方式,让开发者能够轻松...

    jQuery自由拖拽排序插件.zip

    jQuery自由拖拽排序插件是一种基于JavaScript库jQuery的交互式功能,它允许用户通过鼠标拖放操作对元素进行自由排序,常用于创建可自定义排列顺序的列表或网格布局。这种插件在网页开发中非常实用,特别是在需要动态...

    基于jQuery 的图片拖拽排序框架实例代码分享.zip

    6. **持久化**:保存用户排序结果,可以是通过AJAX调用将新的顺序发送到服务器,也可以利用`localStorage`或`sessionStorage`在客户端存储。 7. **恢复状态**:在页面加载或刷新后,根据保存的顺序恢复图片的布局。...

    jQuery拖拽排序

    例如,当拖拽排序结束并保存新顺序后,可以发送一个AJAX请求到服务器,更新数据库中的相应记录。在提供的文件列表中,`example.aspx.cs`可能包含了处理此类请求的服务器端代码,这通常涉及到ASP.NET的后台处理。 `....

    jquery实现可拖动DIV自定义保存到数据的实例

    通过以上分析,可以看出该文件是一个包含前端和后端代码的Web开发实例,着重介绍了如何利用jQuery插件实现一个可拖动的DIV元素列表,并通过JavaScript和PHP脚本将用户操作的结果保存到服务器。这个实例涉及到了Web...

Global site tag (gtag.js) - Google Analytics