时间:2021-05-25
本文介绍了Vue2 SSR 缓存 Api 数据,分享给大家,具体如下:
1. 安装缓存依赖: lru-cache
npm install lru-cache --dev2. api 配置文件
config-server.js
var LRU = require('lru-cache')let apiif (process.__API__) { api = process.__API__} else { api = process.__API__ = { api: 'http://localhost:8080/api/', cached: LRU({ max: 1000, maxAge: 1000 * 60 * 15 }), cachedItem: {} }}module.exports = api配置下lru-cache
3. 封装下 api
import axios from 'axios'import qs from 'qs'import md5 from 'md5'import config from './config-server.js'export default { post(url, data) { const key = md5(url + JSON.stringify(data)) if (config.cached && config.cached.has(key)) { return Promise.resolve(config.cached.get(key)) } return axios({ method: 'post', url: config.api + url, data: qs.stringify(data), // 其他配置 }).then(res => { if (config.cached && data.cache) config.cached.set(key, res) return res }) }}ajax 库我们用axios, 因为axios在 nodejs 和 浏览器都可以使用
并且将 node 端和浏览器端分开封装
import config from './config-server.js'const key = md5(url + JSON.stringify(data))通过 url 和参数, 生成一个唯一的 key
if (config.cached && config.cached.has(key)) { return Promise.resolve(config.cached.get(key))}if (config.cached && data.cache) config.cached.set(key, res)判断下是不是开启了缓存, 并且接口指定缓存的话, 将 api 返回的数据, 写入缓存
注意:
这个 api 会处理所有的请求, 但是很多请求其实是不需要缓存的, 所以需要缓存可以在传过来的 data 里, 添加个 cache: true, 如:
api.post('/api/test', {a: 1, b:2, cache: true})不需要缓存的直接按正常传值即可
当然这里标记是不是要缓存的方法有很多, 不一定要用这一种
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文主要介绍了Vue2SSR渲染根据不同页面修改meta,分享给大家,具体如下:注意:经过测试,vue-meta会导致内存泄漏,请慎用…以现在vue2的服务端渲
花费了一个月时间,终于在新养车之家项目中成功部署了vue2服务端渲染(SSR),并且使用上了Vuex负责状态管理,首屏加载时间从之前4G网络下的1000ms,提
本人对vue不是很懂,搜索了很多关于Vue2无限级分类介绍,下面我来记录一下,有需要了解Vue2无限级分类的朋友可参考。希望此文章对各位有所帮助。Vue树a{c
本文实例讲述了vue2嵌套路由实现方法。分享给大家供大家参考,具体如下:前面讲过了vue2路由基本用法,一般应用中的路由方式不会像上述例子那么简单,往往会出现二
vue2经过2.2版本升级后,文件变成了8个:vue.common.jsvue.esm.jsvue.jsvue.min.jsvue.runtime.common