详解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中subprocess模块的使用
2023-12-05 16:35:05
mysql查询时offset过大影响性能的原因和优化详解
2024-01-13 14:17:36
使用Python绘制三种概率曲线详解
2022-07-27 00:21:01
使用python 将图片复制到系统剪贴中
2021-12-03 22:34:11
用Python画圣诞树代码示例
2023-06-14 06:22:27
Python 分形算法代码详解
2023-05-28 04:18:51
python正则表达式判断字符串是否是全部小写示例
2021-10-10 08:37:40
Python常见字符串操作函数小结【split()、join()、strip()】
2023-07-21 04:58:15
python程序需要编译吗
2022-08-18 12:57:13
python里面单双下划线的区别详解
2023-03-22 12:39:22
python selenium 弹出框处理的实现
2022-12-05 14:19:19
VsCode搭建Go语言开发环境的配置教程
2024-05-11 09:09:02
利用Python实现朋友圈中的九宫格图片效果
2023-07-31 01:37:22
python爬虫scrapy基于CrawlSpider类的全站数据爬取示例解析
2022-12-17 22:26:30
python Matplotlib绘图直线,折线,曲线
2023-01-12 13:44:09
利用mycat实现mysql数据库读写分离的示例
2024-01-12 21:55:52
浅谈python opencv对图像颜色通道进行加减操作溢出
2021-12-26 11:45:23
mysql中GROUP_CONCAT的使用方法实例分析
2024-01-28 01:01:26
python子线程如何有序执行
2022-03-14 01:08:54
更新升级python和pip版本后不生效的问题解决
2022-09-30 18:23:14