前言

缓存是一种重要的程序优化手段,一般采用以空间换时间的措施来提高程序性能,常用的缓存方法有浏览器缓存、HTTP 缓存等。

场景

假设有这样一个简单场景:后台返给前端一组数据做展示,考虑到页面性能问题,前端需要分页来显示。

我们就这个场景需求来做一下代码实现。

实现一

非常常规的实现方式:

  1. // 假设后台返回的数据是一个数组,存在 data 中
  2. function getPagerData(pageNumber, pageSize) {
  3. return data.slice(pageSize * (pageNumber - 1), pageSize * pageNumber);
  4. }

每次点击页面页码时,都要调用 getPagerData 方法来计算出所需要展示的数据。

如果 data 的长度不大,那每次计算应该都很快,一旦 data 的长度较大,那每次计算展示数据的速度就不是那么乐观了。

为了性能和展示的体验效果,后台都将数据一把推了,结果前端因为计算显示数据而导致展示慢,这就有点说不过去了,后台开发说不定还会嘲笑前端不给力呢。

实现二

既然做了分页功能,那就意味着用户可以点击任何一页的页码。如果采用“实现一”中的方案,那即使是之前已经显示过的数据,如果用户想要再次展示,还是要重新计算一遍才行,这要就做了很多重复性的工作,实在是影响性能你。

现在我们做一个这样的优化:

  1. function dataController() {
  2. let catchData = new Map();
  3. return function (pageNumber, pageSize) {
  4. if (!catchData.has(pageNumber)) {
  5. catchData.set(pageNumber, data.slice(pageSize * (pageNumber - 1), pageSize * pageNumber));
  6. }
  7. return catchData.get(pageNumber);
  8. };
  9. }
  10. let getPagerData = dataController();

之后用户每次点击页码时,我们只需要如下调用即可:

  1. const data = getPagerData(pageNumber, pageSize);

然而,作为一名有追求有抱负的新时代程序员,我们会发现一个问题:上面的 dataController 只适用于这一种特定场景,没有可复用性!这哪行,必须改,于是有了下面这个方法:

  1. function dataController(fn) {
  2. let catchData = new Map();
  3. return function (...args) {
  4. if (!catchData.has(args[0])) {
  5. catchData.set(args[0], fn(...args));
  6. }
  7. return catchData.get(args[0]);
  8. }
  9. }
  10. function getPagerData(pageNumber, pageSize) {
  11. return data.slice(pageSize * (pageNumber - 1), pageSize * pageNumber);
  12. }
  13. let getData = dataController(getPagerData);

之后每次需要数据的时候,都可以这样调用:

  1. let data = getData(pageNumer, pageSize);

将具体截取数据的方法当做参数传入,之后如果有不同的截取逻辑,只需要封为函数传入 dataController 即可得到数据,大大提高了代码复用率。

总结

~

~本文完,感谢阅读!

~

学习有趣的知识,结识有趣的朋友,塑造有趣的灵魂!

大家好,我是〖编程三昧〗的作者 隐逸王,我的公众号是『编程三昧』,欢迎关注,希望大家多多指教!

你来,怀揣期望,我有墨香相迎! 你归,无论得失,唯以余韵相赠!

知识与技能并重,内力和外功兼修,理论和实践两手都要抓、两手都要硬!

更多相关文章

  1. 总结mysql 常用DDL, DML语言并实操;
  2. MySql 常用 DDL - DML 语句
  3. 数据库连接及事件委托
  4. MySQL DDL命令大全(数据定义语言)
  5. 【前端 · 面试 】TCP 总结(一)—— 概述
  6. oracle数据库无法打开修复过程
  7. 总结mysql 常用DDL, DML语言并实操与use在命名空间中的作用及实
  8. 补0816:拦截方法封装mysql查询语句
  9. 数据库请求委托代理

随机推荐

  1. android的UriMatcher类
  2. android中获取网络图片
  3. Layout布局
  4. android ImageButton 左中右分段排列
  5. Android(安卓)xUtils框架(一) DbUtils
  6. Android 配置环境
  7. 根据百度地图API得到坐标和地址并在地图
  8. android 4.2 修改默锁屏为无
  9. android实现猜扑克牌小游戏(改进:每次只可
  10. Android trouble shooting 整理