详解Vue2 SSR 缓存 Api 数据
作者:M.M.F 时间:2023-07-02 17:09:06
本文介绍了Vue2 SSR 缓存 Api 数据,分享给大家,具体如下:
1. 安装缓存依赖: lru-cache
npm install lru-cache --dev
2. api 配置文件
config-server.js
var LRU = require('lru-cache')
let api
if (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})
不需要缓存的直接按正常传值即可
当然这里标记是不是要缓存的方法有很多, 不一定要用这一种
来源:https://www.mmxiaowu.com/article/58666e94b31b4b0734dd01be
标签:Vue,SSR,缓存
0
投稿
猜你喜欢
python进阶教程之异常处理
2023-10-14 23:04:17
Python语法学习之进程的创建与常用方法详解
2023-11-08 11:23:34
Python数据结构之顺序表的实现代码示例
2021-02-22 07:13:08
Python决策树之基于信息增益的特征选择示例
2023-01-09 23:44:32
Mysql导入导出工具Mysqldump和Source命令用法详解
2024-01-23 19:46:52
简单聊一聊SQL中的union和union all
2024-01-18 00:17:17
JavaScript 关于引用那点事
2009-11-28 18:44:00
pycharm如何设置官方中文(如何汉化)
2022-04-27 06:20:18
Python爬虫HTPP请求方法有哪些
2023-07-25 16:55:06
八个超级好用的Python自动化脚本(小结)
2021-03-02 14:52:43
编译和解释的区别是什么
2022-04-13 21:52:42
关于python实现requests接口测试的问题
2023-08-27 10:09:18
MySQL索引的基本语法
2024-01-26 00:48:44
Python实现针对给定字符串寻找最长非重复子串的方法
2022-12-05 14:38:53
PyCharm利用pydevd-pycharm实现Python远程调试的详细过程
2022-01-22 19:54:26
oracle 查询表名以及表的列名
2009-07-26 09:33:00
SVN与Git版本控制的优缺点差异全面分析
2023-12-18 13:39:02
解决Python 遍历字典时删除元素报异常的问题
2023-11-17 04:06:47
python实现滑雪游戏
2021-10-08 05:20:35
Python openpyxl 遍历所有sheet 查找特定字符串的方法
2023-08-25 10:22:47