JSP 前端数据本地排序实例代码
发布时间 - 2026-01-11 00:29:25 点击率:次在前端中我们经常需要数据的排序,首先写引入我写好的js
$(function($) {
$('#sclazzId').val($('#voId').val());
document.getElementsByName('nameup')[0].style.display = "none";
document.getElementsByName('nameup')[1].style.display = "none";
document.getElementsByName('nameup')[2].style.display = "none";
document.getElementsByName('nameup')[3].style.display = "none";
var tabobj = document.getElementById("tbValue");
/*
* for (var i = 2; i < tabobj.rows.length; i++) {
*
* if (tabobj.rows[i].cells[1].innerHTML == code) {
*
* tabobj.rows[i].style.backgroundColor = "red";
*
* break; } }
*/
});
function OnChange(code) {
// alert(document.getElementById("drpIndustry").value+"_"+code+".html");
window.location.href = document.getElementById("drpIndustry").value + "_"
+ code + ".html";
}
// 转换器,将列的字段类型转换为可以排序的类型:String,int,float
function convert(sValue, sDataType) {
switch (sDataType) {
case "int":
if (sValue != "--")
return parseInt(sValue);
else
return -10000000000000;
case "float":
if (sValue != "--")
return parseFloat(sValue);
else
return -10000000000000.0;
case "date":
if (sValue != "--")
return new Date(Date.parse(sValue));
else
return "1900-01-01";
default:
return sValue.toString();
}
}
// 排序函数产生器,iCol表示列索引,sDataType表示该列的数据类型
function generateCompareTRs(iCol, sDataType) {
return function compareTRs(oTR1, oTR2) {
var vValue1 = convert(oTR1.cells[iCol].firstChild.nodeValue, sDataType);
var vValue2 = convert(oTR2.cells[iCol].firstChild.nodeValue, sDataType);
if (vValue1 < vValue2) {
return -1;
} else if (vValue1 > vValue2) {
return 1;
} else {
return 0;
}
};
}
// 排序方法
function sortTable(sTableID, iCol, sDataType) {
if (document.getElementsByName('nameup')[parseInt(iCol) - 1].style.display == 'none') {
document.getElementsByName('nameup')[parseInt(iCol) - 1].style.display = 'block';
document.getElementsByName('namedown')[parseInt(iCol) - 1].style.display = 'none';
} else {
document.getElementsByName('nameup')[parseInt(iCol) - 1].style.display = 'none';
document.getElementsByName('namedown')[parseInt(iCol) - 1].style.display = 'block';
}
var oTable = document.getElementById(sTableID);
var oTBody = oTable.tBodies[0];
var colDataRows = oTBody.rows;
var aTRs = new Array;
// 将所有列放入数组
for (var i = 0; i < colDataRows.length; i++) {
aTRs[i] = colDataRows[i];
}
// 判断最后一次排序的列是否与现在要进行排序的列相同,是的话,直接使用reverse()逆序
if (oTable.sortCol == iCol) {
aTRs.reverse();
} else {
// 使用数组的sort方法,传进排序函数
aTRs.sort(generateCompareTRs(iCol, sDataType));
}
var oFragment = document.createDocumentFragment();
for (var i = 0; i < aTRs.length; i++) {
aTRs[i].cells[0].innerHTML = i + 1;
oFragment.appendChild(aTRs[i]);
}
oTBody.appendChild(oFragment);
// 记录最后一次排序的列索引
oTable.sortCol = iCol;
}
function detatilWork(id) {
alert(id);
$.post("", {
id : id
}, function() {
});
}
function reflash() {
window.location.reload(true);
}
function openSearch() {
var name = $('#sname').val();
var clazzId = $('#sclazzId').val();
window.location.href = "assistantWork.action?name=" + name + "&clazzId="
+ clazzId;
}
function lastPage(page) {
var name = $('#sname').val();
var clazzId = $('#sclazzId').val();
page = (page - 1 < 0) ? 0 : (page - 1);
window.location.href = "assistantWork.action?page=" + page + "&name="
+ name + "&clazzId=" + clazzId;
}
function selPage(page) {
var name = $('#sname').val();
var clazzId = $('#sclazzId').val();
window.location.href = "assistantWork.action?page=" + page + "&name="
+ name + "&clazzId=" + clazzId;
}
function nextPage(page, pages) {
var name = $('#sname').val();
var clazzId = $('#sclazzId').val();
page = (page + 1 > pages) ? pages : (page + 1);
window.location.href = "assistantWork.action?page=" + page + "&name="
+ name + "&clazzId=" + clazzId;
}
function detail(id, type) {
$.ajax({
url : 'selectOneWork.action?id=' + id,
async : false, // 同步请求
error : function() {
alert("失败");
},
success : function(data) {
data = eval("(" + data + ")");
$('#workid').val(data.id);
$('#cname').val(data.name);
$('#sclazzIdM').val(data.clazzId);
$('#cdescription').val(data.description);
},
}, 'json');
if(type==1){
//查看 需要改成不可编辑
setDisabled();
}else if(type==2){
cleanDisabled();
}
}
function add(){
cleanDisabled();
}
function setDisabled(){
$('#cname').attr("disabled",true);
$('#sclazzIdM').attr("disabled",true);
$('#cdescription').attr("disabled",true);
$('#submitWork').attr("disabled",true);
}
function cleanDisabled(){
$('#cname').attr("disabled",false);
$('#sclazzIdM').attr("disabled",false);
$('#cdescription').attr("disabled",false);
$('#submitWork').attr("disabled",false);
}
在jsp页面中我们只需要在字段中嵌入这两div就可以实现视觉上的升序或降序,真正实现排序的是字段上面的那个点击事件,事件的执行方法在上面的脚本中都已经写好了,就这么简单,你就实现了表格数据的本地排序,大大的减少了与服务器之间的访问次数。
1.另外在说一句就是在我们的jsp中我们有的时候并不是很需要数据库数据的格式,这个时候我们需要将数据的格式进行转化,转化的方式有很多种,我们可以将数据在后台的时候进行格式处理,但是这样做的话在效率上并不是很快,我们在jsp中就有这样的标签
这样我们就实现了日期的格式化处理,值得注意的是这里的fmt只能用我页面上的布局,不能用工具上的格式化处理,处理过就会影响我们上面的本地排序,所以只能用我的格式
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# JSP前端数据本地排序
# JSP
# 数据本地化
# JSP中的PreparedStatement对象操作数据库的使用教程
# JSP中操作数据库的常用SQL标签用法总结
# JSP使用JDBC连接MYSQL数据库的方法
# JSP基于JDBC的数据库连接类实例
# jsp通过自定义标签库实现数据列表显示的方法
# JSP实现从数据库导出数据到Excel下载的方法
# 的是
# 产生器
# 实现了
# 升序
# 就会
# 好了
# 你就
# 一句
# 就有
# 只需
# 要在
# 我们可以
# 希望能
# 这样做
# 这个时候
# 大大的
# 在上面
# 不能用
# 谢谢大家
# 中都
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
如何获取PHP WAP自助建站系统源码?
百度输入法ai面板怎么关 百度输入法ai面板隐藏技巧
Laravel如何自定义分页视图?(Pagination示例)
装修招标网站设计制作流程,装修招标流程?
中国移动官方网站首页入口 中国移动官网网页登录
Laravel如何记录自定义日志?(Log频道配置)
Laravel观察者模式如何使用_Laravel Model Observer配置
如何用PHP工具快速搭建高效网站?
深圳网站制作培训,深圳哪些招聘网站比较好?
nodejs redis 发布订阅机制封装实现方法及实例代码
网站建设整体流程解析,建站其实很容易!
Laravel怎么生成二维码图片_Laravel集成Simple-QrCode扩展包与参数设置【实战】
Laravel如何实现多表关联模型定义_Laravel多对多关系及中间表数据存取【方法】
HTML透明颜色代码在Angular里怎么设置_Angular透明颜色使用指南【详解】
html5如何实现懒加载图片_ intersectionobserver api用法【教程】
php后缀怎么变mp4格式错误_修改扩展名提示格式不对怎么办【技巧】
php json中文编码为null的解决办法
Android利用动画实现背景逐渐变暗
为什么要用作用域操作符_php中访问类常量与静态属性的优势【解答】
Laravel路由怎么定义_Laravel核心路由系统完全入门指南
如何在浏览器中启用Flash_2025年继续使用Flash Player的方法【过时】
Laravel如何获取当前用户信息_Laravel Auth门面获取用户ID
Laravel API路由如何设计_Laravel构建RESTful API的路由最佳实践
焦点电影公司作品,电影焦点结局是什么?
Chrome浏览器标签页分组怎么用_谷歌浏览器整理标签页技巧【效率】
电视网站制作tvbox接口,云海电视怎样自定义添加电视源?
Laravel软删除怎么实现_Laravel Eloquent SoftDeletes功能使用教程
如何在香港免费服务器上快速搭建网站?
浏览器如何快速切换搜索引擎_在地址栏使用不同搜索引擎【搜索】
北京网页设计制作网站有哪些,继续教育自动播放怎么设置?
悟空识字怎么关闭自动续费_悟空识字取消会员自动扣费步骤
米侠浏览器网页背景异常怎么办 米侠显示修复
Laravel如何集成Inertia.js与Vue/React?(安装配置)
谷歌浏览器如何更改浏览器主题 Google Chrome主题设置教程
Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】
C#如何调用原生C++ COM对象详解
javascript中的数组方法有哪些_如何利用数组方法简化数据处理
Android中AutoCompleteTextView自动提示
Laravel如何使用Guzzle调用外部接口_Laravel发起HTTP请求与JSON数据解析【详解】
Android实现代码画虚线边框背景效果
iOS发送验证码倒计时应用
百度浏览器ai对话怎么关 百度浏览器ai聊天窗口隐藏
html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】
音乐网站服务器如何优化API响应速度?
Laravel如何创建自定义Facades?(详细步骤)
如何在 Go 中优雅地映射具有动态字段的 JSON 对象到结构体
Laravel如何生成URL和重定向?(路由助手函数)
佛山网站制作系统,佛山企业变更地址网上办理步骤?
Windows10怎样连接蓝牙设备_Windows10蓝牙连接步骤【教程】
在线制作视频的网站有哪些,电脑如何制作视频短片?

