侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

JSP 前端数据本地排序实例代码

Java  /  管理员 发布于 7年前   181

在前端中我们经常需要数据的排序,首先写引入我写好的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,floatfunction 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实现仿QQ空间新建多个相册名称并向相册中添加照片功能
    下一条:
    jsp有两个按钮来控制Timer的开始和结束方法
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 在java中实现的脱敏工具类代码示例分享(0个评论)
    • zookeeper安装流程步骤(0个评论)
    • 在java中你背的“八股文”可能已经过时了(2个评论)
    • 在php8.0+版本中使用属性来增加值代码示例(3个评论)
    • java 正则表达式基础,实例学习资料收集大全 原创(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-11
    • 2018-03
    • 2020-03
    • 2023-05
    • 2023-11
    • 2024-01
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客