最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

关于Vue2SSR缓存Api数据的方法

来源:懂视网 责编:小采 时间:2020-11-27 19:34:47
文档

关于Vue2SSR缓存Api数据的方法

关于Vue2SSR缓存Api数据的方法:本篇文章主要介绍了Vue2 SSR 缓存 Api 数据,内容挺不错的,现在分享给大家,也给大家做个参考。本文介绍了Vue2 SSR 缓存 Api 数据,分享给大家,具体如下:1. 安装缓存依赖: lru-cachenpm install lru-cache --dev2. api 配置文件co
推荐度:
导读关于Vue2SSR缓存Api数据的方法:本篇文章主要介绍了Vue2 SSR 缓存 Api 数据,内容挺不错的,现在分享给大家,也给大家做个参考。本文介绍了Vue2 SSR 缓存 Api 数据,分享给大家,具体如下:1. 安装缓存依赖: lru-cachenpm install lru-cache --dev2. api 配置文件co

本篇文章主要介绍了Vue2 SSR 缓存 Api 数据,内容挺不错的,现在分享给大家,也给大家做个参考。

本文介绍了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})

不需要缓存的直接按正常传值即可

当然这里标记是不是要缓存的方法有很多, 不一定要用这一种

文档

关于Vue2SSR缓存Api数据的方法

关于Vue2SSR缓存Api数据的方法:本篇文章主要介绍了Vue2 SSR 缓存 Api 数据,内容挺不错的,现在分享给大家,也给大家做个参考。本文介绍了Vue2 SSR 缓存 Api 数据,分享给大家,具体如下:1. 安装缓存依赖: lru-cachenpm install lru-cache --dev2. api 配置文件co
推荐度:
标签: 方法 数据 缓存
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top