最近的项目中涉及到了用户个性化定制首页的需求,用户要求可以随意拖动首页模块的位置,来实现个性化的布局。本文讲解如何使用jquery和PHP实现拖动布局并将拖动后的布局位置保存到数据库。
很多网站的拖动布局的例子都是采用浏览器的COOKIE来记录用户拖动模块的位置,也就是说拖动后各模块的排序位置信息是记录在客户端的cookie里的。当用户清空客户端的cookie或浏览器的cookie过期后,再次访问页面时,发现布局又还原成最初的状态。这种cookie记录的方式使用简单,但不适合像个人中心、管理系统主页的要求。
本例实现的效果:
- 通过拖动随意布局页面模块。
- 记录拖动后模块的位置,并记录到数据库中。
- 页面永久性布局,用任意浏览器在任意时候打开,页面布局不变。(除非用户再次更改模块的排序,跟cookie没有关系)。
原理
采用jquery ui的sorttable拖动排序插件实现拖动效果。
将拖动后的模块的位置通过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: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.php",
data: { id: newid, order: oldid },
beforeSend: function() {
$show.html("<img src='load.gif' /> 正在更新");
},
success: function(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>
诚然,真正的拖动排序结果的保存都跟每个用户信息相关联,所以数据库的结构设计方面大家可以自行解决,尽情发挥吧。
相关推荐
标题 "Asp.net+JQuery拖拽布局并保存至数据库" 涉及的技术领域主要集中在Web开发,尤其是客户端交互和后端数据处理。这里我们将深入探讨如何利用JQuery实现拖拽布局,以及如何将这种布局信息存储到Asp.net应用程序的...
在JavaScript的世界里,jQuery是一个非常...通过研究和学习这些文件,你可以更好地理解如何结合jQuery和drag.js实现拖拽特效,并将其应用到自己的项目中。这个压缩包是一个很好的起点,帮助你掌握这一重要的前端技术。
本篇文章将深入探讨基于jQuery的拖拽交换与拖拽排序组件,这是一种提升用户界面交互性的重要技术,尤其适用于构建动态列表和可自定义布局的应用。 拖拽交换和拖拽排序功能在网页应用中非常常见,例如在日程管理、...
"jQuery可拖动网格布局排列代码"就是一款利用jQuery库结合gridster.js插件实现的高效解决方案,旨在提供一个可自定义、可拖动的网格布局系统。这篇文章将深入探讨这一技术的实现原理和应用。 首先,jQuery作为一款...
在本文中,我们将探讨如何使用jQuery实现拖动布局功能,并将用户自定义的布局顺序保存到数据库中。这个功能在很多个性化定制的场景下非常有用,例如用户可以在个人中心或管理系统的首页上自由调整模块的位置,以满足...
本篇文章将深入探讨如何使用 jQuery Sortable 实现div的拖动排序效果。 首先,你需要在项目中引入 jQuery 和 jQuery UI 的库。jQuery 是一个广泛使用的JavaScript库,而 jQuery UI 提供了包括Sortable在内的多种...
本篇文章将深入讲解如何使用jQuery UI Drag插件来创建可拖动的浮动div,并将其应用于布局排列,以及如何将排序结果保存到数据库。 **1. jQuery UI Drag插件介绍** jQuery UI是基于jQuery库的一个扩展,它提供了...
5. **数据同步**:拖拽排序完成后,通常需要将新的顺序同步到后台数据库或保存在本地存储中,以便在下次访问时保持用户的排序设置。 通过这个插件,开发者可以快速实现一个交互性强、用户体验良好的拖拽排序功能,...
3. 排序更新:在mouseup事件中,插件会记录当前的元素顺序,并触发特殊的sort事件,供开发者获取新的排序信息,通常用于更新数据库或保存用户设置。 三、源码解析 在解压的文件中,"使用须知.txt"可能包含了一些...
本篇文章将详细解析"jQuery网格拖动图片排序插件特效源码",帮助开发者理解其工作原理,并提供实践指导。 首先,我们需要了解jQuery的基本概念。jQuery是一个快速、简洁的JavaScript库,它简化了HTML文档遍历、事件...
本实例将介绍如何使用PHP、MySQL和JavaScript实现一个拖拽Div的动态效果,并将其数据保存到数据库中,便于后续处理和展示。 **一、JavaScript拖拽功能实现** 1. **事件监听**:首先,我们需要在HTML中为要拖动的...
最后,为了保存用户的排序,可以通过Ajax将新的排序信息发送到服务器端,更新数据库中的记录。同时,为了提供更好的用户体验,可以实时更新页面上图片的顺序,而不仅仅是拖放结束后。 以上就是使用jQuery实现图片...
`update`回调函数会在排序发生改变后被调用,提供了一个接口来处理排序更新的结果,例如将新的顺序保存到后台数据库。 总的来说,"jQuery鼠标上下拖动div排序代码.zip"提供了一套完整的实现方式,让开发者能够轻松...
jQuery自由拖拽排序插件是一种基于JavaScript库jQuery的交互式功能,它允许用户通过鼠标拖放操作对元素进行自由排序,常用于创建可自定义排列顺序的列表或网格布局。这种插件在网页开发中非常实用,特别是在需要动态...
6. **持久化**:保存用户排序结果,可以是通过AJAX调用将新的顺序发送到服务器,也可以利用`localStorage`或`sessionStorage`在客户端存储。 7. **恢复状态**:在页面加载或刷新后,根据保存的顺序恢复图片的布局。...
例如,当拖拽排序结束并保存新顺序后,可以发送一个AJAX请求到服务器,更新数据库中的相应记录。在提供的文件列表中,`example.aspx.cs`可能包含了处理此类请求的服务器端代码,这通常涉及到ASP.NET的后台处理。 `....
通过以上分析,可以看出该文件是一个包含前端和后端代码的Web开发实例,着重介绍了如何利用jQuery插件实现一个可拖动的DIV元素列表,并通过JavaScript和PHP脚本将用户操作的结果保存到服务器。这个实例涉及到了Web...