vue服务端渲染添加缓存的方法
什么是服务器端渲染(SSR)?
Vue.js是构建客户端应用程序的框架。默认情况下,可以在浏览器中输出Vue组件,进行生成DOM和操作DOM。然而,也可以将同一个组件渲染为服务器端的HTML字符串,将它们直接发送到浏览器,最后将这些静态标记"激活"为客户端上完全可交互的应用程序。
服务器渲染的Vue.js应用程序也可以被认为是"同构"或"通用",因为应用程序的大部分代码都可以在服务器和客户端上运行。
缓存
虽然Vue的服务器端渲染(SSR)相当快速,但是由于创建组件实例和虚拟DOM节点的开销,无法与纯基于字符串拼接(purestring-based)的模板的性能相当。在SSR性能至关重要的情况下,明智地利用缓存策略,可以极大改善响应时间并减少服务器负载。
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返回常量将导致组件始终被缓存,这对纯静态组件是有好处的。
接口缓存:
在create-api-server.js中设置缓存
importqsfrom'qs' importaxiosfrom'axios' importmd5from'md5' importLRUfrom'lru-cache' constmicroCache=LRU({ max:100, maxAge:5000//设置数据多久过期 }) exportfunctioncreateAPI({baseUrl,timeout}){ letapi if(process.__API__){api=process.__API__}else{ //定义全局变量process.__API__ api=process.__API__={ get(url,params={}){ constkey=md5(url+JSON.stringify(params)) //判断是否有缓存,直接返回缓存结果 if(params.cache&µCache.get(key)){ console.log('返回缓存') returnPromise.resolve(microCache.get(key)) } returnnewPromise((resolve,reject)=>{ axios({ url, params, headers:{ 'X-Requested-With':'XMLHttpRequest' //'Cookie':parseCookie(SSR.cookies) }, method:'get' }).then(res=>{ //判断是否需要缓存如果需要缓存缓存数据 if(params.cache&µCache){ microCache.set(key,res.data) } console.log('返回新数据') resolve(res.data) }).catch(error=>{ reject(error) }) }) }, post(url,params={}){ constkey=md5(url+JSON.stringify(params)) //判断是否有缓存,直接返回缓存结果 if(params.cache&µCache.get(key)){ returnPromise.resolve(microCache.get(key)) } returnnewPromise((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&µCache){ microCache.set(key,res.data) } resolve(res.data) }).catch(error=>{ reject(error) }) }) } } } returnapi }
总结
以上所述是小编给大家介绍的vue服务端渲染添加缓存的方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对毛票票网站的支持!