jQuery 遍历:思路总结,项目场景中如何处理/控制获取的 each 遍历次数?

文章目录

  • 前言
  • 一、项目场景分析
  • 二、实体类定义描述(仅关键代码)
    • 2.1、实体类定义描述
    • 2.2、逻辑处理与分析
    • 2.3、遍历数据如何修改的问题暴露
  • 三、处理思路
    • 3.1、源码分析 jQuery 中的 each 遍历
    • 3.2、如何解决 jQuery 中控制获取 each 的遍历次数
  • 总结


前言

前台接收到的数据即为 data,里面默认在一个 page 页面显示的是 6 条数据,个别页面可能直接取 6 条数据能够满足我们的需求,但是如果我们在其他页面也从 data 中取数据,数据条数就可能不是 6 条(这里仅说明<=6条的情况——根据实体类的定义走),当我们直接使用 jquery 进行 each 遍历的时候,直接遍历的结果就是 6 条,很有可能就不满足我们的需求,所以,如果在不改变实体类、CSS 样式的情况下,对在 jquery 中获取 each 的遍历次数的控制就是最好的实现方法。

在这里插入图片描述


一、项目场景分析

今天在做一个项目时,遇到了列表遍历的一个问题:定义一个实体类 Page,数据写死,默认每页显示 6 条数据,通过 service 处理 dao 查询数据库的结果,在当前 new 的对象 page 中存放 6 条数据并返给 servlet,servlet 通过返回 json 的形式将 page 对象返回给前台。

前台接收到的数据即为 data,里面默认在一个 page 页面显示的是 6 条数据,个别页面可能直接取 6 条数据能够满足我们的需求,但是如果我们在其他页面也从 data 中取数据,数据条数就可能不是 6 条(这里仅说明 <= 6 条的情况——根据实体类的定义走),当我们直接使用 jquery 进行 each 遍历的时候,直接遍历的结果就是 6 条,很有可能就不满足我们的需求,所以,如果在不改变实体类、CSS 样式的情况下,对在 jquery 中获取 each 的遍历次数的控制就是最好的实现方法。

二、实体类定义描述(仅关键代码)

2.1、实体类定义描述

我们对数据进行分页操作,定义一个实体类 Page,数据写死,默认每页显示 6 条数据,代码如下:

public class Page {private Integer totalPage;// 总页数private Integer totalCount;// 总数据条数private Integer currentPage;// 当前页码private Integer pageCount = 6;// 每页显示条数private List<Route> list;// 每页实际路线数据
}

2.2、逻辑处理与分析

通过 dao 从数据库查询数据,由 service 进行处理分页逻辑并将数据 return 给 servlet,代码如下:

public Page pageQuery(String cid, int cp) {Page page = new Page();//封装5个数据//总条数int totalCount = dao.findTotalCount(cid);page.setTotalCount(totalCount);//当前页码page.setCurrentPage(cp);//每页显示条数//固定每页显示6条//总页数/*** 总条数	每页显示条数	总页数* 29		6		5* 30		6		5* 31		6		6*/int totalPage;if (totalCount % 6 == 0) {totalPage = totalCount / 6;}else {totalPage = totalCount / 6 + 1;}page.setTotalPage(totalPage);//每页实际数据List<Route> list = dao.findList(cid,cp,page.getPageCount());page.setList(list);return page;
}

servlet 将获取到的 page 对象变成 json 形式的字符串发送给前台,前台即接收到处理后的数据 data,代码如下:

Page page = service.pageQuery(cid,cp);
//把数据传给前台
ObjectMapper om = new ObjectMapper();
//把对象变成json形式的字符串
String s = om.writeValueAsString(page);
//发送给前台
response.setContentType("application/json;charset=utf-8");
response.getWriter().write(s);

我们直接使用 jquery 进行 each 遍历的时候,直接遍历的结果就是 6 条,代码如下:

//在添加之前清空之前的数据
$("#popularityroute").html("");
$(data.list).each(function(index,element){var li = '<div class="col-md-3">\n'+'<a href="javascript:;">\n'+'<img src="images/jiangxuan_4.jpg" alt="">\n'+'<div class="has_border">\n'+'<h3>上海直飞三亚5天4晚自由行(春节预售+亲子/蜜月/休闲游首选+豪华酒店任选+接送机)</h3>\n'+'<div class="price">网付价<em></em><strong>1</strong><em></em></div>\n'+'</div>\n'+'</a>\n'+'</div>';//添加到ul里面$("#popularityroute").append(li);
})

遍历结果如下图所示:

在这里插入图片描述

2.3、遍历数据如何修改的问题暴露

但是如果我们在其他页面也从 data 中取数据,数据条数就可能不是 6 条(这里仅说明 <=6 条的情况——根据实体类的定义走),当我们直接使用 jquery 进行 each 遍历的时候,直接遍历的结果就是 6 条,很有可能就不满足我们的需求。我们就需要取 4 条数据显示在本页面,如下图所示:

在这里插入图片描述
而如果不对遍历结果进行处理,就是这样的情况,如下图所示:

在这里插入图片描述
很明显,这是完全不符合我们需求的,这破坏了页面的结构,小心被前端程序员打死哦

在这里插入图片描述
那么为了避免矛盾产生作为 Java 程序员的我们就要对遍历的结果进行处理了。

三、处理思路

3.1、源码分析 jQuery 中的 each 遍历

首先我们先来熟悉一下这个 jquery 中的 each 遍历,代码如下:

//在添加之前清空之前的数据
$("#popularityroute").html("");
$(data.list).each(function(index,element){var li = '<div class="col-md-3">\n'+'<a href="javascript:;">\n'+'<img src="images/jiangxuan_4.jpg" alt="">\n'+'<div class="has_border">\n'+'<h3>上海直飞三亚5天4晚自由行(春节预售+亲子/蜜月/休闲游首选+豪华酒店任选+接送机)</h3>\n'+'<div class="price">网付价<em></em><strong>1</strong><em></em></div>\n'+'</div>\n'+'</a>\n'+'</div>';//添加到ul里面$("#popularityroute").append(li);
})

我们通过console.log来输出一下返给前台数据data的内容,一共是 5 个参数,包含一个存了 6 条数据的list集合,如下图所示:

在这里插入图片描述
通过data.list来获取list的参数,我们再通过console.log来输出一下list的内容以及index索引,每个list即为一个li,由于数据并未处理,所以是 6 条相同的数据,而现在我们仅需要显示前 4 条数据即可,如下图所示:

在这里插入图片描述
在这里插入图片描述

3.2、如何解决 jQuery 中控制获取 each 的遍历次数

显而易见,现在我们只需要对数据的索引进行判断即可。比如如上页面我们仅需要前 4 条数据,我们就可以通过控制索引的值来控制显示数据的条数——达到设定索引值结束遍历。如下图所示:

在这里插入图片描述
解决方式:index 的索引默认是从 0 开始计,显示 4 条数据我们只需要在索引值达到 3 时把遍历停掉即可:

if(index>3){return true;
}

补充:这里使用了 jquery 跳出 each 循环的功能。我们在 Java 中熟悉的是 breakcontinue

而在 jquery 中使用的是:

  • return false——跳出所有循环;相当于 javascript 中的 break 效果
  • return true——跳出当前循环,进入下一个循环;相当于 javascript 中的 continue 效果

这样就满足了我们的需求,同时也不改变后端逻辑与代码,也不会破坏前端页面结构,结果如下图所示:

在这里插入图片描述


总结

优点:通过这个方法,我们基本就可以忽略在实体类中定义的默认一个 page 显示多少条数据的约束,以实体类中的约束作为最大限制即可,只要是在这个范围内的数据我们都可以控制和取到。既也不改变后端逻辑与代码,也不会破坏前端页面结构。 缺点:多余的数据会被隐藏掉,所以在分页中不建议使用,会造成丢失数据的情况。如果仅使用前几条数据进行限制还是没有任何问题的。

在这里插入图片描述


我是白鹿,一个不懈奋斗的程序猿。望本文能对你有所裨益,欢迎大家的一键三连!若有其他问题、建议或者补充可以留言在文章下方,感谢大家的支持!

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

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

相关文章

JavaScript 事件:Web 表单如何实现禁用右键、复制粘贴/剪切和输入框自动填充?

文章目录前言一、禁用鼠标右键1.1、分析说明1.2、操作原理1.3、实现效果1.4、实现代码1.5、补充&#xff1a;JS 中的 button 事件属性二、禁用复制粘贴2.1、分析说明2.2、实现代码三、禁用输入框自动填充功能3.1、分析说明3.2、实现效果3.3、实现代码总结前言 我们在项目中&…

MySQL 模糊查询:MySQL 数据库 like 语句通配符模糊查询小结

MySQL 报错&#xff1a;Parameter index out of range (1 &#xff1e; number of parameters, which is 0)——MySQL 数据库 like 语句通配符模糊查询小结 文章目录MySQL 报错&#xff1a;Parameter index out of range (1 &#xff1e; number of parameters, which is 0)——…

内网击穿之 HTTP 穿透:网站没上线?如何让全世界的人都可以访问你本地的网站?

文章目录前言一、内网穿透原理与工具介绍1.1、内网穿透工作原理1.2、内网穿透工具介绍二、启动内网穿透工具2.1、命令及配置介绍2.2、查看映射信息三、进行访问测试3.1、远程访问本地站点资源3.2、关闭内网穿透总结前言 对于大多数程序员来说&#xff0c;网站一经开发测试后&am…

软件设计原则:内聚、耦合有哪几种类型?内聚度、耦合度如何比较?

文章目录前言一、何为内聚&#xff1f;1.1、7 种内聚类型及其描述二、何为耦合&#xff1f;2.1、7 种耦合类型及其描述总结前言 高内聚、低耦合是我们在软件设计过程中必须遵循的一个重要原则&#xff0c;在整个软件工程中占有很大的比重。而对于内聚和耦合你还是仅仅局限于“高…

数据库管理工具:如何使用 Navicat Premium 转储(导出)和运行(导入)*.sql 文件?

文章目录前言一、转储&#xff08;导出&#xff09;数据库 SQL 文件1.1、选择“转储 SQL 文件”1.2、选择导出文件存放位置1.3、查看转储 SQL 文件界面1.4、查看 SQL 输出文件1.5、查看输出文件详情信息二、运行&#xff08;导入&#xff09;数据库 SQL 文件2.1、新建数据库2.2…

JSP 编译原理:JSP 是 Servlet?如何用 Eclipse 查看 JSP 编译生成的 Servlet 源文件?

文章目录前言一、JSP 文件编译流程原理二、创建并运行待测试 JSP 页面三、查找 JSP 编译文件输出位置3.1、打开动态项目运行配置3.2、查看 JSP 编译文件输出位置3.3、查看 JSP 编译输出文件四、JSP 编译输出 Servlet 的论证五、访问 JSP 文件的流程总结前言 相信大家都了解&…

MVC 模式/Servlet/JSP 编译原理剖析:Servlet 组件到底属于 MVC 模式的哪一层?

文章目录前言一、回忆什么是 MVC 模式&#xff1f;1.1、Model、View、Controller 组件介绍1.2、明确 View 与 Controller 组件区别二、什么是 Servlet&#xff1f;2.1、Servlet 的组件定义2.2、Servlet 组件处于 Controller 层&#xff1f;三、老师说 Servlet 是 View 层的&…

操作系统原理:进程 PV 操作如何计算?全网最全三种前驱图计算类型总结

文章目录前言一、PV 操作定义1.1、P 操作定义1.2、V 操作定义二、串联进程&#xff08;单线前驱图&#xff09;2.1、什么是单线前驱图&#xff1f;2.2、如何计算单线前驱图的 PV&#xff1f;2.2.1、计算前驱节点 PV2.2.2、计算中间节点 PV2.2.3、计算尾节点 PV三、并联进程&…

Spring 容器:三种方式解决 Resource leak: ‘applicationContext‘ is never closed 问题

文章目录前言一、Spring 容器警告产生的场景二、Spring 容器未关闭后果分析2.1、肉眼可见的警告2.2、导致的内存泄漏2.2.1、什么是内存泄漏&#xff1f;2.2.2、如何判断内存泄漏&#xff1f;2.2.3、Java 中的 GC&#xff08;垃圾回收&#xff09;2.2.4、Java 中会导致内存泄漏的…

SRA 案例:关于华为开发者联盟基础服务文档内容的改进建议(华为开发者联盟文档深度体验官)

文章目录前言一、文档中心的外链跳转问题1.1、问题描述1.2、造成的问题1.3、改进建议二、图片失真和无法放大查看问题2.1、问题描述2.2、造成的问题2.3、改进建议三、个别 SDK 词汇缺少必要的说明3.1、问题描述3.2、造成的问题3.3、改进建议四、邮箱信息的优化4.1、问题描述4.2…

腾讯位置服务:有何优势?如何使用平台创建应用和服务调用的 Key?

文章目录前言一、腾讯位置服务的优势1.1、提供丰富的地图产品1.2、提供行业解决方案1.3、提供其他生态维度的支持1.4、海量的数据基础1.5、丰富的开发文档二、初识腾讯位置服务2.1、用户的注册与登录&#xff08;附专属邀请码&#xff09;2.2、开发者信息的完善三、创建服务平台…

毕业生当头一棒?忆本科四年,高校毕业生与就业单位基本要求差多少?工作还是考研?

文章目录前言一、大学本科前两年的生活1.1、庸庸碌碌、中规中矩1.2、收获了爱情二、大三的改变2.1、学会自律2.2、学会自我总结2.3、眼光要具有前瞻性三、毕业答辩3.1、个人设计答辩3.2、团队设计答辩四、南京之行4.1、铭记历史&#xff0c;感恩先辈4.2、加强自我认知与提升五、…

Gitee 答疑:为什么从 Gitee 平台 Pull 代码到 STS/Eclipse 后文件乱码?逐步排查

文章目录前言一、产生乱码场景1.1、错误描述1.2、解决思路二、解决方式2.1、检查 Git 平台上的源码2.2、Git 的运行原理2.3、修改 IDE 的文本编码格式2.4、重新打开目的文件问题解决2.5、仍存在问题看这里&#xff08;重新拉区合并&#xff09;总结前言 我们从 Gitee 平台 Pull…

flash 异常修复:QQ 的 flash 图标显示异常?QQ 秀、表情加载异常?一招解决

文章目录前言一、产生错误场景1.1、flash 图标显示异常1.2、解决思路二、安装合适版本的 Flash Player2.1、选择合适版本的 Flash Player2.2、安装 Flash Player三、重启 QQ 客户端四、flash 动画加载异常4.1、动画加载异常原因分析4.2、下载安装 flash 修复工具4.3、使用 Flas…

电脑广告多?Windows 自带恶意软件删除工具还不会使用?有必要安装杀毒软件吗?

文章目录前言一、启动恶意软件删除工具二、扫描类型的选择三、启动软件扫描四、恶意软件删除工具的说明五、对于恶意软件处理的建议总结前言 可能有些小伙伴发现&#xff0c;哎&#xff1f;为什么我的电脑弹窗广告这么多&#xff1f;难不成小视频看多了&#xff1f;电脑中毒了&…

《软件项目管理(第二版)》第 8 章——项目团队与干系人 重点部分总结

文章目录 前言一、简答题二、论述题总结前言 学习了项目的开发与发布之后,我们就可以单独对一个项目进行开发了,但是在企业中开发中,除了编码之外,还需要项目管理、团队协作开发等,这就是软件项目管理板块要学习的内容。本文是对《软件项目管理(第二版)》第 8 章——项目…

《软件项目管理(第二版)》第 7 章——项目风险管理 重点部分总结

文章目录 前言一、单选题二、填空题三、简答题四、论述题总结前言 学习了项目的开发与发布之后,我们就可以单独对一个项目进行开发了,但是在企业中开发中,除了编码之外,还需要项目管理、团队协作开发等,这就是软件项目管理板块要学习的内容。本文是对《软件项目管理(第二…

《软件项目管理(第二版)》第 6 章——项目质量管理 重点部分总结

文章目录 前言一、单选题二、判断题三、简答题总结前言 学习了项目的开发与发布之后,我们就可以单独对一个项目进行开发了,但是在企业中开发中,除了编码之外,还需要项目管理、团队协作开发等,这就是软件项目管理板块要学习的内容。本文是对《软件项目管理(第二版)》第 6…

《软件项目管理(第二版)》第 5 章——项目进度和成本管理 重点部分总结

文章目录 前言一、填空题二、简答题三、论述题总结前言 学习了项目的开发与发布之后,我们就可以单独对一个项目进行开发了,但是在企业中开发中,除了编码之外,还需要项目管理、团队协作开发等,这就是软件项目管理板块要学习的内容。本文是对《软件项目管理(第二版)》第 5…

《软件项目管理(第二版)》第 1 章——概述 重点部分总结

文章目录 前言一、填空题二、判断题三、简答题总结前言 学习了项目的开发与发布之后,我们就可以单独对一个项目进行开发了,但是在企业中开发中,除了编码之外,还需要项目管理、团队协作开发等,这就是软件项目管理板块要学习的内容。本文是对《软件项目管理(第二版)》第 1…