vue服务端渲染缓存应用详解
服务端渲染简介
服务端渲染不是一个新的技术;在Web最初的时候,页面就是通过服务端渲染来返回的,用PHP来说,通常是使用Smarty等模板写模板文件,然后PHP服务端框架将数据和模板渲染为页面返回,这样的服务端渲染有个缺点就是一旦要查看新的页面,就需要请求服务端,刷新页面。
但如今的前端,为了追求一些体验上的优化,通常整个渲染在浏览器端使用JS来完成,配合history.pushState等方式来做单页应用(SPA:Single-PageApplication),也收到不错的效果,但是这样还是有一些缺点:第一次加载过慢,用户需要等待较长时间来等待浏览器端渲染完成;对搜索引擎爬虫等不友好。这时候就出现了类似于React,Vue2.0等前端框架来做服务端渲染。
本文重点给大家介绍vue服务端渲染缓存应用,先看下vue缓存分为哪几种吧。
vue缓存分为页面缓存、组建缓存、接口缓存,这里我主要说到了页面缓存和组建缓存
页面缓存:
在server.js中设置
constLRU=require('lru-cache')
constmicroCache=LRU({
max:100,//最大缓存的数目
maxAge:1000//重要提示:条目在1秒后过期。
})
constisCacheable=req=>{
//判断是否需要页面缓存
if(req.url&&req.url==='/'){
returnreq.url
}else{
returnfalse
}
}
app.get('*',(req,res)=>{
constcacheable=isCacheable(req)
if(cacheable){
consthit=microCache.get(req.url)
if(hit){
returnres.end(hit)
}
}
consterrorHandler=err=>{
if(err&&err.code===404){
//未找到页面
res.status(404).sendfile('public/404.html');
}else{
//页面渲染错误
res.status(500).end('500-InternalServerError')
console.error(`errorduringrender:${req.url}`)
console.error(err)
}
}
constcontext={
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){
returnerrorHandler(err)
}
res.end(html)
microCache.set(req.url,html)//设置当前缓存页面的内容
})
})
组建缓存:
在server.js中设置如下:
functioncreateRenderer(bundle,template){
returnrequire('vue-server-renderer').createBundleRenderer(bundle,{
template,
cache:LRU({
max:1000,
maxAge:1000*60*5//组建缓存时间
})
})
}
letrenderer
if(isProd){
//生产环境使用本地打包文件来渲染
constbundle=require('./output/vue-ssr-bundle.json')
consttemplate=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)
})
}
要缓存的组建
exportdefault{
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返回常量将导致组件始终被缓存,这对纯静态组件是有好处的。
总结
以上所述是小编给大家介绍的vue服务端渲染缓存应用详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!