【前端】Jquery UI +PHP 实现表格拖动排序

目的:使用jquery ui库实现对表格拖拽排序,并且把排序保存到数据库中

效果如下

一、准备工作:

1、下载jquery ui库,可以直接引用线上路径

<link rel="stylesheet" href="https://code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css">
<script src="https://code.jquery.com/ui/1.12.1/jquery-ui.min.js"></script>

2、前端我使用的是layui,后端是PHP

二、使用

逻辑说明

1、引入jqueryui库

2、js代码使用jqueryui的update()方法,获取拖动的条目id和当前页码,发送到后台

3、由于我这里后端使用了thinkphp的paginate进行分页,所以为保证在非第一页的拖拽顺序能后前后连上,对页码进行判断,当page=0或page=1时,都令page=1,当page大于1时,令page=page-1,在本身页码上减1

4、生成连续序号:设置每页显示条数pageSize(要和分页时条数一致),拿第3步计算的page乘以pageSize,再加上1,比如说第1页:(page*pageSize)+1 => (0*15)+1=1,(0*15)+2=2,...第2页时:(1*15)+1=16,(1*15)+2=17,目的是在分页时使sort条目新序号能够连接上,不会出现每翻一页都要从1开始的情况(第一页:1、2、3、...15,第二页:16、17...30,第三页:31、32...)

5、遍历所有条目,在sort的基础上加上遍历的索引值$key,为每一条目生成新的序号,最后更新数据库

前端代码

<table class="layui-table box_table" lay-skin="nob" lay-size="lg" style=" text-align: center;" id="sort"><thead><tr><td>课件名</td><td>课件类型</td><td>发送班级</td></tr></thead><tbody><tr><td>内容...</td><td>内容...</td><td>内容...</td></tr></tbody>
</table>

JS代码

function GetQueryString(name){var reg = new RegExp("(^|&)"+ name +"=([^&]*)(&|$)");var r = window.location.search.substr(1).match(reg);if(r!=null)return  unescape(r[2]); return null;}// 拖拽排序$(document).ready(function () {$("#sort tbody").sortable({update:function () {var idArr = [];$("input[name='id']").each(function() {		//遍历每一行的ID值idArr.push($(this).val());		//把拍完序的数据ID依次推入数组})var page = GetQueryString('page')console.log(idArr)console.log(page)$.ajax({type: "POST",dataType: "json",url: "upsort",data:{idArr:idArr,page:page},success:function (res) {console.log(res)layer.msg(res.message, { icon:1, time: 1000 }, function(){window.location.reload()});},error:function (request) {console.log(request);}});}})})

注意:在table外面的加上id="sort",选择器应该选中表格sort下的tbody

后端控制器

public function upsort(){if (request()->isPost()) {$data = input('post.');$page=$data['page'] ? $data['page']-1 : 0;$res = model('Kejian')->upsort($data['idArr'],$page);if ($res) {return apiResponse('200','操作成功');}else{return apiResponse('110','操作失败');}}else{return apiResponse('110','非法请求');}}

 后端model模型

public function upsort($idArr,$page){$pageSize = 15;     //每页显示条数,与列表分页保持一致$sort = ($page * $pageSize)+1;Db::startTrans();try {foreach ($idArr as $key => $value) {Db::table('kejian')->update(['id'=>$value,'sort'=>$sort+$key]);}Db::commit();return true;} catch (Exception $e) {Db::rollback();return false;}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/136492.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

IS-LM模型:从失衡到均衡的模拟

IS-LM模型&#xff1a;从失衡到均衡的模拟 文章目录 IS-LM模型&#xff1a;从失衡到均衡的模拟[toc] 1 I S − L M 1 IS-LM 1IS−LM模型2 数值模拟2.1 长期均衡解2.2 政府部门引入2.3 价格水平影响2.4 随机扰动因素 1 I S − L M 1 IS-LM 1IS−LM模型 I S − L M IS-LM IS−LM是…

如何在CPU上进行高效大语言模型推理

大语言模型&#xff08;LLMs&#xff09;已经在广泛的任务中展示出了令人瞩目的表现和巨大的发展潜力。然而&#xff0c;由于这些模型的参数量异常庞大&#xff0c;使得它们的部署变得相当具有挑战性&#xff0c;这不仅需要有足够大的内存空间&#xff0c;还需要有高速的内存传…

python中return和print的区别

1、功能不同 return是返回计算值&#xff1b; print是打印数据到屏幕。 return返回的结果不能直接输出到控制台&#xff0c;需要通过print才能打印出来。 举例如下&#xff1a; # 导入flask模块 from flask import Flask# 实例化一个flask项目&#xff0c;项目名为app app…

无需标注海量数据,目标检测新范式OVD

当前大火的多模态GPT-4在视觉能力上只具备目标识别的能力&#xff0c;还无法完成更高难度的目标检测任务。而识别出图像或视频中物体的类别、位置和大小信息&#xff0c;是现实生产中众多人工智能应用的关键&#xff0c;例如自动驾驶中的行人车辆识别、安防监控应用中的人脸锁定…

智慧工地源码 手册文档 app 数据大屏、硬件对接、萤石云

智慧工地解决方案依托计算机技术、物联网、云计算、大数据、人工智能、VR、AR等技术相结合&#xff0c;为工程项目管理提供先进技术手段&#xff0c;构建工地现场智能监控和控制体系&#xff0c;弥补传统方法在监管中的缺陷&#xff0c;最终实现项目对人、机、料、法、环的全方…

ZZ308 物联网应用与服务赛题第E套

2023年全国职业院校技能大赛 中职组 物联网应用与服务 任 务 书 &#xff08;E卷&#xff09; 赛位号&#xff1a;______________ 竞赛须知 一、注意事项 1.检查硬件设备、电脑设备是否正常。检查竞赛所需的各项设备、软件和竞赛材料等&#xff1b; 2.竞赛任务中所使用的…

文件包含漏洞培训

CTF介绍 MISC(Miscellaneous)类型,即安全杂项,题目或涉及流量分析、电子取证、人肉搜索、数据分析等等。CRYPTO(Cryptography)类型,即密码学,题目考察各种加解密技术,包括古典加密技术、现代加密技术甚至出题者自创加密技术。PWN类型,PWN在黑客俚语中代表着攻破、取得权限…

【JS】Chapter11-正则阶段案例

站在巨人的肩膀上 黑马程序员前端JavaScript入门到精通全套视频教程&#xff0c;javascript核心进阶ES6语法、API、js高级等基础知识和实战教程 &#xff08;十一&#xff09;正则&阶段案例 1. 正则表达式 1.1 介绍 正则表达式&#xff08;Regular Expression&#xff0…

21 移动网络的前世今生

1、移动网络的发展历程 发展过程就是&#xff1a;2G,3G,4G,5G的过程&#xff0c;用2G看txt&#xff0c;用3G看jpg&#xff0c;用4G看avi。 2、2G网络 手机本来是用来打电话的&#xff0c;不是用来上网的&#xff0c;所以原来在2G时代&#xff0c;上网使用的不是IP网络&#…

Ubuntu 安装最新版python

首先&#xff0c;打开终端并更新包列表&#xff1a; sudo apt update 然后&#xff0c;你需要安装一些依赖的软件包来构建Python源码。可以使用下面的命令来安装这些依赖&#xff1a; sudo apt install -y build-essential zlib1g-dev libncurses5-dev libgdbm-dev libnss3-…

关于视频封装格式和视频编码格式的简介

文章目录 简介视频封装格式&#xff08;Video Container Format&#xff09;视频编码格式&#xff08;Video Compression Format&#xff09;两者关系总结webm 格式简介webm视频编码格式webm音频编码格式webm总结 简介 视频封装格式&#xff08;Video Container Format&#x…

直方图学习

直方图均衡化&#xff08;Histogram Equalization&#xff09;是一种用于增强图像对比度的图像处理技术&#xff0c;通过重新分配图像的像素值&#xff0c;使图像中的亮度级别更加均匀&#xff0c;以改善图像的视觉质量。下面是进行直方图均衡化的一般步骤&#xff1a; 计算原始…

sql学习

因为之前sql学的太烂了&#xff0c;想整理一下 一.什么是 SQL&#xff1f; SQL 是用于访问和处理数据库的标准的计算机语言。 SQL 指结构化查询语言SQL 使我们有能力访问数据库SQL 是一种 标准计算机语言 二.SQL 能做什么&#xff1f; SQL 面向数据库执行查询SQL 可从数据库…

2020 ICPC 澳门(G,J,I)详解

链接&#xff1a;The 2020 ICPC Asia Macau Regional Contest G Game on Sequence 题意 给定长度为 n n n 数组 a i a_i ai​&#xff0c;A与G博弈&#xff0c;G先手&#xff0c;给定初始位置 k k k&#xff0c;若当前在 i i i 点转移到 j j j&#xff0c;满足 i <…

【编程语言发展史】SQL的发展历史

目录 目录 SQL概述 SQL发展历史 SQL特点 SQL基本语句 SQL是结构化查询语言(Structure Query Language)的缩写&#xff0c;它是使用关系模型的数据库应用语言&#xff0c;由IBM在70年代开发出来&#xff0c;作为IBM关系数据库原型System R的原型关系语言&#xff0c;实现了…

uni-app使用echarts数据不更新

问题描述 uni-app使用echarts图表&#xff0c;接口请求数据更新后&#xff0c;图表不刷新。 解决方案 更新option前先调用clear() clear()&#xff1a;清空当前实例&#xff0c;会移除实例中所有的组件和图表。 initChart() {this.gaugeChart echarts.init(document.getE…

安卓常见设计模式5------桥接模式(Kotlin版)

1. W1 是什么&#xff0c;什么是桥接模式&#xff1f; 桥接模式是一种结构性模式。 桥接模式旨在将抽象与实现解耦&#xff0c;使它们可以独立地变化。可以这么理解&#xff0c;面向对象编程是单继承多实现的&#xff0c;如果我们有一个可扩展类&#xff0c;和多个相关的可扩展…

农业4.0中麦田的精确杂草检测:实现技术、方法和研究挑战的综述

Precision weed detection in wheat fields for agriculture 4.0: A survey of enabling technologies, methods, and research challenges 摘要1、引言2、相关工作3、麦田常见杂草的种类及分布特征3.1 天然麦田中常见的杂草3.2 杂草分布格局4、先进的麦田杂草检测技术4.1 光谱…

MySQL -- 用户管理

MySQL – 用户管理 文章目录 MySQL -- 用户管理一、用户1.用户信息2.创建用户3.删除用户4.远端登录MySQL5.修改用户密码6.数据库的权限 一、用户 1.用户信息 MySQL中的用户&#xff0c;都存储在系统数据库mysql的user表中&#xff1a; host&#xff1a; 表示这个用户可以从…

关于Alibaba Cloud Toolkit 下载配置以及后端自动部署

idea中File-Settings-Plugins 搜索Alibaba Cloud Toolkit点击下载&#xff0c;下载完成重启 1、点击 Tools-Alibaba Cloud-Deploy to Host 部署到主机 2、配置服务器ip、jar包启动命令、服务器jar存放位置 3、设置服务器ip用户名密码&#xff0c;点击测试连接情况 4、配置脚本…