`

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

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

原理
采用jquery ui的sorttable拖动排序插件实现拖动效果。
将拖动后的模块的位置通过ajax传给服务端PHP程序。
PHP程序处理位置信息后,更新数据库中相应的字段内容。


<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:left; width:200px; height:140px; margin:10px; border:1px solid #acc6e9; background:#e8f5fe} .m_title{height:24px; line-height:24px; background:#afc6e9}
 #loader{height:24px; text-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.jsp", //服务端处理程序 
                       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和后台程序交互了。
首先别忘了加载jquery库和jquery ui的sortable拖动排序插件。

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










分享到:
评论
1 楼 masuweng 2019-03-19  
求代码,谢谢.

相关推荐

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

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

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

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

    基于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