vue服务端渲染缓存应用详解
服务端渲染简介
服务端渲染不是一个新的技术;在 web 最初的时候,页面就是通过服务端渲染来返回的,用 php 来说,通常是使用 smarty 等模板写模板文件,然后 php 服务端框架将数据和模板渲染为页面返回,这样的服务端渲染有个缺点就是一旦要查看新的页面,就需要请求服务端,刷新页面。
但如今的前端,为了追求一些体验上的优化,通常整个渲染在浏览器端使用 js 来完成,配合 history.pushstate 等方式来做单页应用(spa: single-page application),也收到不错的效果,但是这样还是有一些缺点:第一次加载过慢,用户需要等待较长时间来等待浏览器端渲染完成;对搜索引擎爬虫等不友好。这时候就出现了类似于 react,vue 2.0 等前端框架来做服务端渲染。
本文重点给大家介绍vue服务端渲染缓存应用,先看下vue缓存分为哪几种吧。
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服务端渲染缓存应用详解 ,希望对大家有所帮助
上一篇: Python使用socket实现组播与发送二进制数据
下一篇: java中对象,属性,和方法的关系?