什么是服务器端渲染(SSR)?html
Vue.js 是构建客户端应用程序的框架。默认状况下,能够在浏览器中输出 Vue 组件,进行生成 DOM 和操做 DOM。然而,也能够将同一个组件渲染为服务器端的 HTML 字符串,将它们直接发送到浏览器,最后将这些静态标记"激活"为客户端上彻底可交互的应用程序。vue
服务器渲染的 Vue.js 应用程序也能够被认为是"同构"或"通用",由于应用程序的大部分代码均可以在服务器和客户端上运行。java
缓存webpack
虽然 Vue 的服务器端渲染(SSR)至关快速,可是因为建立组件实例和虚拟 DOM 节点的开销,没法与纯基于字符串拼接(pure string-based)的模板的性能至关。在 SSR 性能相当重要的状况下,明智地利用缓存策略,能够极大改善响应时间并减小服务器负载。ios
vue服务区缓存分为页面缓存、组建缓存和接口缓存程序员
页面缓存 :web
在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)
// 设置当前缓存页面的内容
})
})
|
组建缓存 :json
在server.js中设置以下:axios
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 下载地址:百度网盘下载