概念
keep-alive是vue的内置组件,可以包裹动态路由和组件,会缓存不活动的组件实例,而不是销毁它们。和 transition 相似,keep-alive 是一个抽象组件:它自身不会渲染成一个 DOM 元素,也不会出现在父组件链中。
作用
防止重复渲染DOM,减少加载时间及性能消耗,提高用户体验性。
属性
include - 字符串或正则表达式。只有名称匹配的组件会被缓存。
exclude - 字符串或正则表达式。任何名称匹配的组件都不会被缓存。
max - 数字。最多可以缓存多少组件实例。
生命周期函数
1 activated
在 keep-alive 组件激活时调用
该钩子函数在服务器端渲染期间不被调用
2 deactivated
在 keep-alive 组件停用时调用
该钩子在服务器端渲染期间不被调用
注意: 只有组件被 keep-alive 包裹时,这两个生命周期函数才会被调用,如果作为正常组件使用,是不会被调用的,以及在 2.1.0 版本之后,使用 exclude 排除之后,就算被包裹在 keep-alive 中,这两个钩子函数依然不会被调用!另外,在服务端渲染时,此钩子函数也不会被调用。
缓存所有页面
<keep-alive>
<router-view/>
</keep-alive>入代码片
</