vue服务端渲染添加缓存的方法


什么是服务器端渲染(SSR)?

Vue.js 是构建客户端应用程序的框架。默认情况下,可以在浏览器中输出 Vue 组件,进行生成 DOM 和操作 DOM。然而,也可以将同一个组件渲染为服务器端的 HTML 字符串,将它们直接发送到浏览器,最后将这些静态标记"激活"为客户端上完全可交互的应用程序。

服务器渲染的 Vue.js 应用程序也可以被认为是"同构"或"通用",因为应用程序的大部分代码都可以在服务器和客户端上运行。

缓存

虽然 Vue 的服务器端渲染(SSR)相当快速,但是由于创建组件实例和虚拟 DOM 节点的开销,无法与纯基于字符串拼接(pure string-based)的模板的性能相当。在 SSR 性能至关重要的情况下,明智地利用缓存策略,可以极大改善响应时间并减少服务器负载。

vue服务区缓存分为页面缓存、组建缓存和接口缓存

页面缓存 :

在server.js中设置

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
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中设置如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
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)
  })
}

要缓存的组建

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
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 返回常量将导致组件始终被缓存,这对纯静态组件是有好处的。

接口缓存:

在create-api-server.js中设置缓存

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
import qs from 'qs'
import axios from 'axios'
import md5 from 'md5'
import LRU from 'lru-cache'
const microCache = LRU({
  max: 100,
  maxAge: 5000 // 设置数据多久过期
})
export function createAPI({baseUrl, timeout}) {
let api
if (process.__API__) { api = process.__API__ } else {
// 定义全局变量 process.__API__
   api = process.__API__ = {
    get(url, params = {}) {
     const key = md5(url + JSON.stringify(params))
     // 判断是否有缓存,直接返回缓存结果
     if (params.cache && microCache.get(key)) {
      console.log( '返回缓存' )
      return Promise.resolve(microCache.get(key))
     }
     return new Promise((resolve, reject) => {
      axios({
       url,
       params,
       headers: {
        'X-Requested-With' : 'XMLHttpRequest'
        // 'Cookie': parseCookie(SSR.cookies)
       },
       method: 'get'
      }).then(res => {
       // 判断是否需要缓存 如果需要缓存缓存数据
       if (params.cache && microCache) {
        microCache.set(key, res.data)
       }
       console.log( '返回新数据' )
       resolve(res.data)
      }). catch (error => {
       reject(error)
      })
     })
    },
    post(url, params = {}) {
     const key = md5(url + JSON.stringify(params))
     // 判断是否有缓存,直接返回缓存结果
     if (params.cache && microCache.get(key)) {
      return Promise.resolve(microCache.get(key))
     }
     return new Promise((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 && microCache) {
        microCache.set(key, res.data)
       }
       resolve(res.data)
      }). catch (error => {
       reject(error)
      })
     })
    }
   }
  }
return api
}

 

 

Java Socket应用---通信是这样练成的    下载地址:百度网盘下载
java基础面试题精选(包含答案)    下载地址:百度网盘下载
史上最全面的JavaWeb视频教程    下载地址:百度网盘下载
传智java基础+就业班32期完整版 50G    下载地址:百度网盘下载
SpringMvc(Spring4版本)+Axure RP7.0从入门到精通 视频教程    下载地址:百度网盘下载
JavaEE就业班第168期高清不加密版 (全)视频教程 百度云网盘下载 72G    下载地址:百度网盘下载
传智播客java第33期基础班+就业班 视频教程 教学视频 百度网盘下载 55G    下载地址:百度网盘下载
传智播客上海java培训就业班 视频教程 教学视频 百度网盘下载 32G    下载地址:百度网盘下载
潭州学院大型企业内部技术 java课程 视频教程 教学视频 百度网盘下载(价值400元)    下载地址:百度网盘下载
Java零基础入门教程+就业实战全套视频教程    下载地址:百度网盘下载
北大青鸟java学士后培训视频教程全套    下载地址:百度网盘下载
传智播客.NET培训第24期 就业班 视频教程 教学视频 百度网盘下载 37G    下载地址:百度网盘下载
传智播客.NET培训 基础+就业班 视频教程 教学视频 百度网盘下载    下载地址:百度网盘下载
黑马JavaEE + Android就业班视频教程 教学视频 百度网盘下载 60G    下载地址:百度网盘下载
达内Java 菜鸟零基础学习JAVA视频教程 教学视频 百度网盘下载    下载地址:百度网盘下载
天下网校 Java教程视频 基础入门到精通 核心技术程序设计 教学视频    下载地址:百度网盘下载
web层最火框架——SpringMVC    下载地址:百度网盘下载
传智播客黑马程序员JavaEE28期就业班    下载地址:百度网盘下载
黑马程序员传智播客16期淘淘商城完整版视频教程    下载地址:百度网盘下载
2016.07.17黑马就业班32期JavaEE    下载地址:百度网盘下载


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM