网站首页 > 技术文章 正文
作者:大搜车前端团队博客
网址:
http://f2e.souche.com/blog/ru-he-xie-ge-jian-dan-de-fen-ye/
好基友现在也是个前端,昨天他问我说:
公司的大部分任务都能应付着做了,
现在要做个分页,如果用插件的话,很快就能上,
但是我想提升一下自己,怎么从头开始写一个呢,实在是一点思路也没有。
我想,很多自学前端的同学都会遇到这样一个坎儿,我能做很多东西,但是感觉自己还是啥都不会。
编程,很重要的一个技能就是抽象能力,就是现实中的琐事儿,我怎么用代码来表示。(是表示哈,不是人工智能)
我特别崇拜 ACM 的获奖者,我们公司的死月大大就曾经是 ACM 全国一等奖哦,快过来膜拜。
ACM 是做一些 c 语言算法题,但是你从中可以看到,那些题目都是从生活的例子出发,然后就得到了这样一个用 c 语言可以编程的题。
现在回归那个分页。
我们先看一下简单的需求。
当前页码前后显示 3 页,然后需要显示第一页和最后一页
未显示的页码用省略号表示。
举例:如果总共 110 页
当前页码为 1,那么显示 1 2 3 4 ... 110 下一页
当前页码为 2,那么显示 上一页 1 2 3 4 5 ... 110 下一页
当前页码为 3,那么显示 上一页 1 2 3 4 5 6 ... 110 下一页
当前页码为 4,那么显示 上一页 1 2 3 4 5 6 7 ... 110 下一页
当前页码为 5,那么显示 上一页 1 2 3 4 5 6 7 8 ... 110 下一页
当前页码为 6,那么显示 上一页 1 ... 3 4 5 6 7 8 9 ... 110 下一页
…
当前页码为 100,那么显示 上一页 1 ... 97 98 99 100 101 102 103 ... 110 下一页
…
当前页码为 109,那么显示 上一页 1 ... 106 107 108 109 110 下一页
当前页码为 110,那么显示 上一页 1 ... 107 108 109 110
那么你可能就看出来了,虽然每一页在实际应用中都是一个超链接,但是我们在思考算法时可以先将其忽略。
现在就变成了一个简单的字符串输出题。
我们先定义一个函数
function showPages (page, total) {
}
盲目的就开始码代码一定是个不好的习惯,码代码之前,我们要先准备好覆盖所有情况的测试。
这个题就简单咯,我们可以把所有结果都打印出来呗。
在无需引入一个代码测试库的情况下,我们来这么干
var total = 110;
for (var i = 1; i <= total; i++) {
var ret = showPages(i, total);
console.log(ret);
}
就从页码为 1 到最后一页的结果全输出出来了。
我之所以崇拜 ACM 大神,是因为我算法能力其实一般般,所以献丑贴代码一定不要笑话我哦,咱说好,本文讲的是解决问题的思维模式。
function showPages (page, total) {
var str = page + '';
for (var i = 1; i <= 3; i++) {
if (page - i > 1) {
str = page - i + ' ' + str;
}
if (page + i < total) {
str = str + ' ' + (page + i);
}
}
if (page - 4 > 1) {
str = '... ' + str;
}
if (page > 1) {
str = '上一页 ' + 1 + ' ' + str;
}
if (page + 4 < total) {
str = str + ' ...';
}
if (page < total) {
str = str + ' ' + total + ' 下一页';
}
return str;
}
- 上一篇: 手速太快引发分页翻车?前端竞态陷阱揭秘
- 下一篇: Elasticsearch深度分页
猜你喜欢
- 2025-05-11 FANUC修改前端目录教程
- 2025-05-11 前端分享-Set你不知道的事
- 2025-05-11 jq+ajax+bootstrap改了一个动态分页的表格
- 2025-05-11 千万级大表分页查询效率剧降,你会怎么办?
- 2025-05-11 Elasticsearch深度分页
- 2025-05-11 手速太快引发分页翻车?前端竞态陷阱揭秘
- 2024-09-21 浅谈MySQL分页查询的工作原理
- 2024-09-21 使用Vue创建一个分页组件
- 2024-09-21 GO语言札记-分页技术实现
- 2024-09-21 SSM 框架!实现分页和搜索分页
你 发表评论:
欢迎- 06-24发现一款开源宝藏级工作流低代码快速开发平台
- 06-24程序员危险了,这是一个 无代码平台+AI+code做项目的案例
- 06-24一款全新的工作流,低代码快速开发平台
- 06-24如何用好AI,改造自己的设计工作流?
- 06-24濮阳网站开发(濮阳网站建设)
- 06-24AI 如何重塑前端开发,我们该如何适应
- 06-24应届生靠这个Java简历模板拿下了5个offer
- 06-24服务端性能测试实战3-性能测试脚本开发
- 567℃几个Oracle空值处理函数 oracle处理null值的函数
- 566℃Oracle分析函数之Lag和Lead()使用
- 550℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 546℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 545℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 536℃【数据统计分析】详解Oracle分组函数之CUBE
- 526℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 519℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)