vue服务区缓存(页面缓存、组建缓存和接口缓存)实例讲解
时间:2018-09-18
本文章向大家介绍vue服务区缓存(页面缓存、组建缓存和接口缓存)实例讲解,需要的朋友可以参考一下
缓存
虽然 Vue 的服务器端渲染(SSR)相当快速,但是由于创建组件实例和虚拟 DOM 节点的开销,无法与纯基于字符串拼接(pure string-based)的模板的性能相当。在 SSR 性能至关重要的情况下,明智地利用缓存策略,可以极大改善响应时间并减少服务器负载。
vue服务区缓存分为页面缓存、组建缓存和接口缓存
页面缓存:
在server.js中设置
const LRU = require('lru-cache') const microCache = LRU({ max: 100, // 最大缓存的数目 maxAge: 1000 // 重要提示:条目在 1 秒后过期。 }) const isCacheable = req => { //判断是否需要页面缓存 if (req.url && req.url === '/') { return req.url } else { return false } } app.get('*', (req, res) => { const cacheable = isCacheable(req) if (cacheable) { const hit = microCache.get(req.url) if (hit) { return res.end(hit) } } const errorHandler = err => { if (err && err.code === 404) { // 未找到页面 res.status(404).sendfile('public/404.html'); } else { // 页面渲染错误 res.status(500).end('500 - Internal Server Error') console.error(`error during render : ${req.url}`) console.error(err) } } const context = { title: 'vue', keywords: 'vue-ssr服务端脚手架', description: 'vue-ssr-template, vue-server-renderer', version: v, url: req.url, cookies: req.cookies } renderer.renderToString(context, (err, html) => { if (err) { return errorHandler(err) } res.end(html) microCache.set(req.url, html) // 设置当前缓存页面的内容 }) })
组建缓存:
在server.js中设置如下:
function createRenderer(bundle, template) { return require('vue-server-renderer').createBundleRenderer(bundle, { template, cache: LRU({ max: 1000, maxAge: 1000 * 60 * 5 // 组建缓存时间 }) }) } let renderer if (isProd) { // 生产环境使用本地打包文件来渲染 const bundle = require('./output/vue-ssr-bundle.json') const template = fs.readFileSync(resolve('./output/index.html'), 'utf-8') renderer = createRenderer(bundle, template) } else { // 开发环境使用webpack热更新服务 require('./build/dev-server')(app, (bundle, template) => { renderer = createRenderer(bundle, template) }) }
要缓存的组建
export default { name: 'Home', title() { return { title: 'vue-ssr', keywords: 'vue-ssr服务端脚手架, home', description: 'vue-ssr-template, vue-server-renderer, home' } }, created() { }, computed: {}, asyncData({ store }) {}, methods: {}, serverCacheKey: props => props.id }
serverCacheKey
返回的 key 应该包含足够的信息,来表示渲染结果的具体情况。如果渲染结果仅由 props.item.id
决定,则上述是一个很好的实现。但是,如果具有相同 id 的 item 可能会随时间而变化,或者如果渲染结果依赖于其他 prop,则需要修改 serverCacheKey
的实现,以考虑其他变量。如果 serverCacheKey返回常量将导致组件始终被缓存,这对纯静态组件是有好处的。
接口缓存:
在create-api-server.js中设置缓存
import qs from 'qs' import axios from 'axios' import md5 from 'md5' import LRU from 'lru-cache'
const microCache = LRU({ max: 100, maxAge: 5000 // 设置数据多久过期 })
export function createAPI({baseUrl, timeout}) { let api
if (process.__API__) { api = process.__API__ } else { // 定义全局变量 process.__API__ api = process.__API__ = { get(url, params = {}) { const key = md5(url + JSON.stringify(params)) // 判断是否有缓存,直接返回缓存结果 if (params.cache && microCache.get(key)) { console.log('返回缓存') return Promise.resolve(microCache.get(key)) } return new Promise((resolve, reject) => { axios({ url, params, headers: { 'X-Requested-With': 'XMLHttpRequest' // 'Cookie': parseCookie(SSR.cookies) }, method: 'get' }).then(res => { // 判断是否需要缓存 如果需要缓存缓存数据 if (params.cache && microCache) { microCache.set(key, res.data) } console.log('返回新数据') resolve(res.data) }).catch(error => { reject(error) }) }) }, post(url, params = {}) { const key = md5(url + JSON.stringify(params)) // 判断是否有缓存,直接返回缓存结果 if (params.cache && microCache.get(key)) { return Promise.resolve(microCache.get(key)) } return new Promise((resolve, reject) => { axios({ url, data: qs.stringify(params), method: 'post', headers: { 'X-Requested-With': 'XMLHttpRequest', 'Content-Type': 'application/x-www-form-urlencoded' // 'Cookie': parseCookie(SSR.cookies) } }).then(res => { // 判断是否需要缓存 如果需要缓存缓存数据 if (params.cache && microCache) { microCache.set(key, res.data) } resolve(res.data) }).catch(error => { reject(error) }) }) } } } return api }
这样就ok了
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法