vue服务端渲染页面缓存和组件缓存的实例详解


Posted in Javascript onSeptember 18, 2018

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返回常量将导致组件始终被缓存,这对纯静态组件是有好处的。

总结

以上所述是小编给大家介绍的vue服务端渲染页面缓存和组件缓存的实例详解,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
javascript创建数组之联合数组的使用方法示例
Dec 26 Javascript
jQuery对象的length属性用法实例
Dec 27 Javascript
JQuery显示、隐藏div的几种方法简明总结
Apr 16 Javascript
每天一篇javascript学习小结(String对象)
Nov 18 Javascript
jQuery对象与DOM对象转换方法详解
May 10 Javascript
BootStrap Table 获取同行不同列元素的方法
Dec 19 Javascript
Angularjs中三种数据的绑定策略(“@”,“=”,“&”)
Dec 23 Javascript
javascript数据结构之串的概念与用法分析
Apr 12 Javascript
vue router+vuex实现首页登录验证判断逻辑
May 17 Javascript
在vue中获取微信支付code及code被占用问题的解决方法
Apr 16 Javascript
vue element upload实现图片本地预览
Aug 20 Javascript
Electron实现应用打包、自动升级过程解析
Jul 07 Javascript
从Vuex中取出数组赋值给新的数组,新数组push时报错的解决方法
Sep 18 #Javascript
vue服务端渲染添加缓存的方法
Sep 18 #Javascript
在Vuex使用dispatch和commit来调用mutations的区别详解
Sep 18 #Javascript
微信小程序开发之路由切换页面重定向问题
Sep 18 #Javascript
在小程序中使用canvas的方法示例
Sep 17 #Javascript
webpack4打包vue前端多页面项目
Sep 17 #Javascript
node中的密码安全(加密)
Sep 17 #Javascript
You might like
Codeigniter中集成smarty和adodb的方法
2016/03/04 PHP
ThinkPHP打水印及设置水印位置的方法
2016/10/14 PHP
js DataSet数据源处理代码
2010/03/29 Javascript
基于jQuery的message插件实现右下角弹出消息框
2011/01/11 Javascript
利用a标签自动解析URL分析网址实例
2014/10/20 Javascript
jQuery中的pushStack实现原理和应用实例
2015/02/03 Javascript
延时加载JavaScript代码提高速度
2015/12/27 Javascript
关于angularJs指令的Scope(作用域)介绍
2016/10/25 Javascript
bootstrap输入框组件使用方法详解
2017/01/19 Javascript
jQuery绑定事件方法及区别(bind,click,on,live,one)
2017/08/14 jQuery
js最简单的双向绑定实例讲解
2018/01/02 Javascript
详解Webpack + ES6 最新环境搭建与配置
2018/06/04 Javascript
详解create-react-app 自定义 eslint 配置
2018/06/07 Javascript
JS严格模式原理与用法实例分析
2020/04/27 Javascript
webpack 如何同时输出压缩和未压缩的文件的实现步骤
2020/06/05 Javascript
[02:51]DOTA2战队出征照拍摄花絮 TI3明星化身时尚男模
2013/07/22 DOTA
[56:56]VG vs LGD 2019国际邀请赛淘汰赛 胜者组 BO3 第一场 8.22
2019/09/05 DOTA
用python实现面向对像的ASP程序实例
2014/11/10 Python
Python列表append和+的区别浅析
2015/02/02 Python
python实现数值积分的Simpson方法实例分析
2015/06/05 Python
深入学习python的yield和generator
2016/03/10 Python
对python创建及引用动态变量名的示例讲解
2018/11/10 Python
python url 参数修改方法
2018/12/26 Python
python basemap 画出经纬度并标定的实例
2019/07/09 Python
使用 Python 处理3万多条数据只要几秒钟
2020/01/19 Python
python判断正负数方式
2020/06/03 Python
浅谈Python中的继承
2020/06/19 Python
美国知名日用品连锁超市:Dollar General(多来店)
2017/01/14 全球购物
加拿大百叶窗和窗帘定制网站:Blinds
2017/01/30 全球购物
Laura官网:加拿大女性的顶级时尚目的地
2019/09/20 全球购物
几个Linux面试题笔试题
2012/12/01 面试题
工程专业求职自荐书范文
2014/02/18 职场文书
陈欧的广告词
2014/03/18 职场文书
大学教师师德师风演讲稿
2014/08/22 职场文书
黄石寨导游词
2015/02/05 职场文书
CSS完成视差滚动效果
2021/04/27 HTML / CSS