Home > Article > Web Front-end > Sample code for vue server-side rendering cache application
The content of this article is about the sample code of vue server-side rendering cache application. It has certain reference value. Friends in need can refer to it. I hope it will be helpful to you.
Vue cache is divided into page cache, component cache, and interface cache. Here I mainly talk about page cache and interface cache.
Page cache:
Set in server.js
const LRU = require('lru-cache')
const microCache = LRU({ max: 100, // 最大缓存的数目 maxAge: 1000 // 重要提示:条目在 1 秒后过期。 }) const isCacheable = req => { //判断是否需要页面缓存<br> if (req.url && req.url === '/') {<br> return req.url<br> } else {<br><em id="__mceDel"><em id="__mceDel"> return false<br></em></em><em id="__mceDel"><em id="__mceDel"><em id="__mceDel"><em id="__mceDel"><em id="__mceDel"> }<br></em></em></em></em></em><em id="__mceDel">}</em>
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) }) })
<em id="__mceDel"> </em>
Component cache:
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) }) }
Component to be cached
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 The returned key should contain enough information to represent the specific situation of the rendering result. The above is a good implementation if the rendering result is determined only by props.item.id . However, if items with the same id may change over time, or if the rendering results depend on other props, the implementation of serverCacheKey will need to be modified to account for other variables. If serverCacheKey returns a constant, it will cause the component to always be cached, which is good for purely static components.
Related recommendations:
Vue Nuxt.js makes server-side rendering
How to use Vue Nuxt.js to implement services Side rendering
The above is the detailed content of Sample code for vue server-side rendering cache application. For more information, please follow other related articles on the PHP Chinese website!