php sortable 动态排序
php sortable 动态排序未分页版.php
预览图:
<?php
mysql_connect("localhost","root","root");
mysql_select_db("test");
mysql_query("SET CHARACTER SET GB2312");
if($_POST["reorder"]){
$i=1;
foreach ($_POST["fruit"] as $fruit_id){
$query="update `fruit` set `order`='$i' where `id`='$fruit_id'";
mysql_query($query);
$i++;
}
}
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>宋正河作品--php sortable 动态排序未分页版</title>
<style>
ul li{
font-size:14px;
list-style-type:none;
background:#33CCFF;
margin:5px;
padding:5px;
border:1px solid #666666;
width:300px;
cursor:pointer;
}
</style>
<script language="JavaScript" type="text/javascript" src="js/jquery-1.4.2.min.js"></script>
<script language="JavaScript" type="text/javascript" src="js/jquery-ui.js"></script>
<script language="JavaScript" type="text/javascript" src="js/ui.core.js"></script>
<script language="JavaScript" type="text/javascript" src="js/ui.sortable.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$('#fruit_list').sortable();
});
</script>
</head>
<body>
<div align="center">
<form name="form1" method="post" action="">
<ul id="fruit_list">
<?php
$query="select * from `fruit` order by `order` ASC";
$result=mysql_query($query);
while($row=mysql_fetch_assoc($result)){
echo '<li><input type="hidden" name="fruit[]" value="'.$row["id"].'" />'.'ID:'.$row["id"].' | '.'名称:'.$row["name"].' | '.'序号:'.$row["order"].'</li>';
}
?>
</ul>
<input type="submit" name="reorder" value="重新排序" />
</form>
拖动相应的项目进行排序,序号越小越靠前
</div>
</body>
</html>
php sortable 动态排序分页版.php
预览图:
<?php
mysql_connect("localhost","root","root");
mysql_select_db("test");
mysql_query("SET CHARACTER SET GB2312");
//分页函数 调用 $common_func->pages();$total_num为总记录数,$page_id为当前页码,$add为链接地址(可选),$pagesize为新闻条数
function pages($total_num,$page_id,$add,$pagesize){
$total_page=ceil($total_num/$pagesize);
$up=$page_id-1;
$down=$page_id+1;
if($page_id==1){
echo "<<首页 ";
}else{
echo "<a href=".$add."page_id=1><<首页</a> ";
}
if($up<1){
$up=1;
echo "<span style=\"color:grey;\"><上一页</span> ";
}else {
echo "<a href=".$add."page_id=".$up."><上一页</a> ";
}
echo "<select onchange=\"window.location='".$add."page_id='+this.value;\">";
for($i=1;$i<=$total_page;$i++){
if($i==$page_id){
echo "<option value=\"".$i."\" selected=\"selected\"> ".$i."/".$total_page." </option>";
}else{
echo "<option value=\"".$i."\"> ".$i."/".$total_page." </option>";
}
}
echo "</select>";
if($down>$total_page){
$down=$total_page;
echo " <span style=\"color:grey;\">下一页></span> ";
}else {
echo " <a href=".$add."page_id=".$down.">下一页></a> ";
}
if($page_id==$total_page){
echo "尾页>>";
}else{
echo "<a href=".$add."page_id=$total_page>尾页>></a>";
}
echo " 共".$total_num."条记录 每页显示".$pagesize."条";
}
//分页函数
$page_id=intval(trim($_GET["page_id"]));
$page_id=($page_id=="")?"1":$page_id;
$page_id=($page_id>0)?$page_id:"1";
$pagesize=intval(trim($_GET["pagesize"]));
$pagesize=($pagesize=="")?"3":$pagesize;
$pagesize=($pagesize>0)?$pagesize:"3";
$begin=($page_id-1)*$pagesize;
if($_POST["reorder"]){
$i=$begin+1;
foreach ($_POST["fruit"] as $fruit_id){
$query="update `fruit` set `order`='$i' where `id`='$fruit_id'";
mysql_query($query);
$i++;
}
}
?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>宋正河作品--php sortable 动态排序分页版</title>
<style>
ul li{
font-size:14px;
list-style-type:none;
background:#33CCFF;
margin:5px;
padding:5px;
border:1px solid #666666;
width:300px;
cursor:pointer;
}
</style>
<script language="JavaScript" type="text/javascript" src="js/jquery-1.4.2.min.js"></script>
<script language="JavaScript" type="text/javascript" src="js/jquery-ui.js"></script>
<script language="JavaScript" type="text/javascript" src="js/ui.core.js"></script>
<script language="JavaScript" type="text/javascript" src="js/ui.sortable.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$('#fruit_list').sortable();
});
</script>
</head>
<body>
<div align="center">
<form name="form1" method="post" action="">
<ul id="fruit_list">
<?php
$query="select * from `fruit` order by `order` ASC";
$result=mysql_query($query);
$total_num=mysql_num_rows($result);
$add="?";
$query=$query." limit $begin,$pagesize";
pages($total_num,$page_id,$add,$pagesize);
$result=mysql_query($query);
while($row=mysql_fetch_assoc($result)){
echo '<li><input type="hidden" name="fruit[]" value="'.$row["id"].'" />'.'ID:'.$row["id"].' | '.'名称:'.$row["name"].' | '.'序号:'.$row["order"].'</li>';
}
?>
</ul>
<input type="submit" name="reorder" value="重新排序" />
</form>
拖动相应的项目进行排序,序号越小越靠前<br />
<a href="?pagesize=<?php echo $total_num;?>">显示全部</a> | <a href="?pagesize=3">分页显示</a>
</div>
</body>
</html>
test.sql
-- phpMyAdmin SQL Dump
-- version 3.1.5-rc1
-- http://www.phpmyadmin.net
--
-- 主机: localhost
-- 生成日期: 2011 年 01 月 08 日 06:22
-- 服务器版本: 5.0.18
-- PHP 版本: 5.2.8
SET SQL_MODE="NO_AUTO_VALUE_ON_ZERO";
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */;
/*!40101 SET @OLD_CHARACTER_SET_RESULTS=@@CHARACTER_SET_RESULTS */;
/*!40101 SET @OLD_COLLATION_CONNECTION=@@COLLATION_CONNECTION */;
/*!40101 SET NAMES utf8 */;
--
-- 数据库: `test`
--
-- --------------------------------------------------------
--
-- 表的结构 `fruit`
--
CREATE TABLE IF NOT EXISTS `fruit` (
`id` int(11) unsigned NOT NULL auto_increment,
`name` varchar(256) NOT NULL,
`order` int(4) NOT NULL,
PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=gb2312 AUTO_INCREMENT=7 ;
--
-- 导出表中的数据 `fruit`
--
INSERT INTO `fruit` (`id`, `name`, `order`) VALUES
(1, '苹果', 5),
(2, '西瓜', 2),
(3, '菠萝', 1),
(4, '桃子', 4),
(5, '樱桃', 3),
(6, '桔子', 6);
这篇文章是受他人的启发,自己抽空参照网友的文章写的,大家多提意见,原文本空间也顺便转了一下,在它的基础上改进了一些东西,希望大家喜欢,谢谢~
php sortable 动态排序的更多相关文章
- ActiveReports 报表应用教程 (9)---交互式报表之动态排序
在 ActiveReports 中除了提供对数据源进行排序的功能之外,还提供了最终用户排序功能,最终用户可以对报表进行区域内排序和整个数据源排序,结合数据钻取.过滤等功能可以让用户更方便地分析报表数据 ...
- linq扩展之动态排序
前两天看QQ群里面,一位朋友问的问题,说在linq中怎么实现动态排序呢,自己想了半天,没有头绪,网上找了下相关的资料,看了下,收益挺多,记录下来. 之前我们没有如果不知道动态排序的方法的话,我们可能会 ...
- excel动态去重和动态排序
其实去重和排序的方法很多,没有哪一种更好,实时去重总会省一些时间,刚好也练习了下数组公式 动态去重: =IF(ROW()<=COUNTA(员工基础数据!H:H),INDEX(员工基础数据!H:H ...
- 构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(17)-LinQ动态排序
原文:构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(17)-LinQ动态排序 首先修复程序中的一个BUG这个BUG在GridPager类中,把sord修改为s ...
- LinQ动态排序
LinQ动态排序 首先修复程序中的一个BUG这个BUG在GridPager类中,把sord修改为sort这个名称填写错误,会导致后台一直无法获取datagrid的排序字段 本来是没有这一讲的,为了使2 ...
- 写一个针对IQueryable<T>的扩展方法支持动态排序
所谓的动态排序是指支持任意字段.任意升序降序的排序.我们希望在客户端按如下格式写: localhost:8000/api/items?sort=titlelocalhost:8000/api/item ...
- Java如何操作对象(bean)进行动态排序?
原文出自:https://blog.csdn.net/seesun2012 简介如题:Java如何操作对象(bean)进行动态排序?Java实体类(bean)动态排序? 原理:利用反射根据指定的属性值 ...
- 动态排序JavaBean
Java中如果对对象排序可以考虑实现Comparable接口,但是需要排序的属性一旦指定就不能再修改.BeanUtils组件提供了对JavaBean动态排序的支持,即可以在运行时指定排序的属性.实例运 ...
- MySQL 按照数据库表字段动态排序 查询列表信息
MySQL 按照数据库表字段动态排序 查询列表信息 背景描述 项目中数据列表分页展示的时候,前端使用的Table组件,每列自带对当前页的数据进行升序或者降序的排序. 但是客户期望:随机点击某一列的时候 ...
随机推荐
- python xml.etree ElementTree解析 编辑 xml
python有很多种xml解析方式,不过感觉etree的ElementTree 用起来最方便. #coding=utf-8 from xml.etree import ElementTree impo ...
- CentOS下如何查找大文件
在Windows系统中,我们可以使用TreeSize工具查找一些大文件或文件夹,非常的方便高效,在Linux系统中,如何去搜索一些比较大的文件呢?下面我整理了一下在Linux系统中如何查找大文件或文件 ...
- Data Flow ->> Raw File Source & Raw File Destination
Raw File Source & Raw File Destination一般用在当有某个package在导入数据或者处理数据需要花费非常长的时间的情况下,可以通过把一些处理好的数据先存到r ...
- 一个n位的数,去掉其中的k位,问怎样去使得留下来的(n-k)位数按原来的前后顺序组成的数最小
例如 8314925去掉4个数,留下125最小,注意有前后顺序要求,要是没有顺序当然是123. 解决方案 贪心算法,在每次被访问的位置保证有最优解. 思路一 分析:求一共n位,求其中的m位组成的数最小 ...
- !! This tutorial was designed to help you with installation and configuration of OpenCV4Android SDK.
ref: http://docs.opencv.org/doc/tutorials/introduction/android_binary_package/O4A_SDK.html#running-o ...
- ado执行sql查询出现“发送数据流时出现算术溢出”错误
开发一个数据采集监控系统,比较变态的是有将近2000项数据.根据数据类型分多个表存储.数据库访问层采用ado.最近发现当一条sql一次性查询1700多个字段数据后就出现“发送数据流时出现算术溢出”错误 ...
- 【POJ】3398 Perfect Service
1. 题目描述某树形网络由$n, n \in [1, 10^4]$台计算机组成.现从中选择一些计算机作为服务器,使得每当普通计算机恰好与一台服务器连接(并且不超过一台).求需要指定服务器的最少数量 2 ...
- Codeforces Round #320 (Div. 2) D. "Or" Game 数学
D. "Or" Game time limit per test 2 seconds memory limit per test 256 megabytes input stand ...
- 51nod1421 最大MOD值
O(n2)tle.O(nlognlogn) #include<cstdio> #include<cstring> #include<cctype> #include ...
- jQuery小例子
map遍历数组 //=========for循环遍历========== var arr[1,2,3,4,5]; for(var i=0;i<=arr.length;i++) { arr[i]= ...