欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue服务端渲染缓存应用

程序员文章站 2024-02-06 20:34:16
vue缓存分为页面缓存、组建缓存、接口缓存,这里我主要说到了页面缓存和组建缓存 页面缓存: 在server.js中设置 组建缓存: 在server.js中设置如下: 要缓存的组建 serverCacheKey 返回的 key 应该包含足够的信息,来表示渲染结果的具体情况。如果渲染结果仅由 props ......

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