什么是服务器端渲染(SSR)?
Vue.js 是构建客户端应用程序的框架。默认情况下,可以在浏览器中输出 Vue 组件,进行生成 DOM 和操作 DOM。然而,也可以将同一个组件渲染为服务器端的 HTML 字符串,将它们直接发送到浏览器,最后将这些静态标记"激活"为客户端上完全可交互的应用程序。
服务器渲染的 Vue.js 应用程序也可以被认为是"同构"或"通用",因为应用程序的大部分代码都可以在服务器和客户端上运行。
缓存
虽然 Vue 的服务器端渲染(SSR)相当快速,但是由于创建组件实例和虚拟 DOM 节点的开销,无法与纯基于字符串拼接(pure string-based)的模板的性能相当。在 SSR 性能至关重要的情况下,明智地利用缓存策略,可以极大改善响应时间并减少服务器负载。
vue服务区缓存分为页面缓存、组建缓存和接口缓存
页面缓存 :
在server.js中设置
{
//判断是否需要页面缓存
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中设置如下:
{
renderer = createRenderer(bundle,template)
})
}
要缓存的组建
props.id
}
serverCacheKey 返回的 key 应该包含足够的信息,来表示渲染结果的具体情况。如果渲染结果仅由 props.item.id 决定,则上述是一个很好的实现。但是,如果具有相同 id 的 item 可能会随时间而变化,或者如果渲染结果依赖于其他 prop,则需要修改 serverCacheKey 的实现,以考虑其他变量。如果 serverCacheKey 返回常量将导致组件始终被缓存,这对纯静态组件是有好处的。
接口缓存:
在create-api-server.js中设置缓存
{
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,直接返回缓存结果
if (params.cache && microCache.get(key)) {
return Promise.resolve(microCache.get(key))
}
return new Promise((resolve,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
}
总结
以上所述是小编给大家介绍的vue服务端渲染添加缓存的方法 。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持。