小編給大家分享一下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})不需要緩存的直接按正常傳值即可
以上是“Vue2中SSR如何緩存Api 數據”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。