前端缓存处理[通俗易懂]

前端缓存处理[通俗易懂]前端的缓存原来是这样做的!

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全家桶1年46,售后保障稳定

前端缓存处理

在开发过程中,总有一些使用频率很高的接口,数据内容还不基本不修改的数据。为了提高效率,自然要放到缓存中。

后端将数据放入redis,那么前端放到哪呢?

通常的选择是localStorage、sessionStorage中。

1.前端的缓存位置区别:

简单说明,详细区别可自行百度。

localStorage: 永久保存,浏览器关闭也不会消失。除非手动清除数据。

sessionStorage:暂时保存,缓存的数据时间是会话级别的。不会永久保存。

2.js工具类代码:

/** * 根据字典编码获取字典数据 * 注意:此方法是异步方法,需要用.then(res => {})获取返回值 * @param {string} code 字典编码 * @returns 字典数据 */
async getCodeList(code) { 
   
  let codeList = sessionStorage.getItem(code);
  // 校验这个数据是否可用
  if (StringUtil.isEmpty(codeList)) { 
   
    // 此处同步调用接口,是防止方法已经结束了,但是数据还没获取到。(这里使用await,方法就必须是async修饰的)
    await sysCode.itemCodes({ 
   code: code}).then((res) => { 
   
      // 存数据时都需要用JSON进行转换。
      sessionStorage.setItem(code, JSON.stringify(res));
      codeList = JSON.stringify(res);
    })
  }
  return JSON.parse(codeList);
},

/** * 根据字典编码和字典数据的id获取该字典数据的名称 * 注意:调用此方法的位置要确保当前系统已经调用过同文件中的getCodeList方法,并且code一致 * @param {string} code 字典编码 * @param {number} id 字典数据的id * @returns {String} 字典数据的名称 */
getCodeName(code, id) { 
   
  id = parseInt(id);
  let codeList = sessionStorage.getItem(code);
  return JSON.parse(codeList).filter(e => e.valueId === id)[0].valueName;
},

Jetbrains全家桶1年46,售后保障稳定

3.页面中的使用:

/** * 获取下拉框数据 */
select() { 
   
  // 异步方法需要使用.then()获取数据
  sysCodeUtil.getCodeList("type").then(res => { 
   
    this.type = res;
  })
},

// 此处粘一行代码说明getCodeName的使用
res.data.type = sysCodeUtil.getCodeName("type", res.data.type);

使用时根据具体使用环境具体选择放到sessionStorage中还是localStorage中,我这里是放到了sessionStorage中。

我是做java的,js并不是非常熟悉,把这个方案想出来用了一两天的时间。

最开始没有这个方法并没有加异步,写完了这个工具类之后发现系统第一次调用的时候,方法已经结束了但是没有获取到值。

sessionStorage中也有值,就是返回值没有数据。后来发现是调用接口的时候异步执行,方法结束后才会调用接口。(最开始不太明白js的异步执行规则,后来才知道的)

加上异步之后就可以解决这个问题了,调用的时候会把数据获取到再返回。

我这里是这样做的,我感觉不是最优解,但是我只想到了这种方式,有大佬有更好的方式欢迎在评论区评论!

有什么问题,也欢迎在评论区留言!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/206690.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 二叉树层次遍历算法——C/C++

    二叉树层次遍历算法——C/C++二叉树层序遍历1、算法思想用一个队列保存被访问的当前节点的左右孩子以实现层序遍历。在进行层次遍历的时候,设置一个队列结构,遍历从二叉树的根节点开始,首先将根节点指针入队列,然后从队头取出一个元素,每取一个元素,执行下面两个操作:访问该元素所指向的节点若该元素所指节点的左右孩子节点非空,则将该元素所指节点的左孩子指针和右孩子指针顺序入队。此过程不断进行,当队列为空时,二叉树的层次遍历结束…

    2022年6月5日
    30
  • centos安装tomcat「建议收藏」

    centos安装tomcat「建议收藏」一、安装安装jdk:https://www.cnblogs.com/Createsequence/p/11445211.html1上传安装包3启动tomcat二、如果tomcat启动过慢

    2022年8月16日
    8
  • linuxnodejs安装及环境配置_nodejs不是内部外部命令

    linuxnodejs安装及环境配置_nodejs不是内部外部命令安装环境本机系统:Windows10Pro(64位)Node.js:14.17.5(64位)安装Node.js步骤《1》下载对应你系统的Node.js版本:https://nodejs.org/en/download/《2》选安装目录进行安装《3》环境配置《4》测试前期准备(1)进入官网下载地址下载Node.js(2)如果要下载指定版本既可选择下边链接开始安装(1)下载完成后,双击“node-v6.9.2-x64.msi”,开始安装Nod..

    2025年11月25日
    4
  • golang2020激活码【在线破解激活】

    golang2020激活码【在线破解激活】,https://javaforall.net/100143.html。详细ieda激活码不妨到全栈程序员必看教程网一起来了解一下吧!

    2022年3月16日
    58
  • OSSIM资料

    OSSIM资料OSSIM 资料 nbsp nbsp nbsp nbsp nbsp nbsp nbsp OSSIM 是一个用于遥感 图片处理 地理信息系统 照相测量方面的高性能软件 是自 1996 年开发至今 由 http www ossim org 网站维护的开源项目 项目的开发人员们拥有在商业和政府遥感系统和应用软件领域多年的经验 OSSIM 由美国多个在智能 防务领域的政府部门提供资助 其技术被研究和实践领域广为应用 OSSIM 的名称来源于 OpenSource

    2025年9月12日
    3
  • c语言运行后电脑很卡,如何让电脑提速,电脑卡是什么原因?

    c语言运行后电脑很卡,如何让电脑提速,电脑卡是什么原因?前言昨天的文章被限制了,正在申诉刚好最近有网友问小编这样一个问题:花了六千买的独显笔记本,用了才一年就卡的不行了,请问电脑卡是什么原因?小编对电脑还算颇有研究,看了网友电脑配置并不算低,导致电脑卡的原因主要在于系统优化与一些硬件方面的问题,下面小编就来说说如何让电脑提速。正文电脑卡是什么原因?导致电脑卡的原因有很多,综合来看,无非就是软件与硬件的问题。其中,软件层面主要是系统优化,硬件方面则主要是…

    2022年6月7日
    41

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号