这篇文章主要讲解了vue中keep-alive内置组件缓存的用法,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。

需求:
home 组件中有一个 name 的 data 数据。这个数据修改之后,再切换到其他的组件。再切换到 home 组件,希望 home 中 name 这个值是之前修改过的值。希望组件有缓存。
keep-alive 的使用方式:
将要缓存的组件使用 keep-alive 包裹住即可。
keep-alive优点的介绍:
1. 切换组件时,当前组件不会触发销毁的生命周期钩子。也就是说不会销毁了。
2. 切换回来时,也不会重新创建。(既然都没有被销毁,哪里来的重新创建呢)
3. 会多出两个生命周期的钩子函数
a. activated 缓存激活 第一次会触发、组件能被看到
一般根 created 做一样的事情:请求数据
b.deactivated 缓存失活 组件不能被看到
一般根 beforeDestroy 做一样的事情: 清除定时器、移除全局事件监听
4. 可以在 vue devtools 上看见组件的缓存情况
** keep-alive 的更多属性设置**
1. include 包含
a. include=“组件1,组件2” 注意 逗号前后不要有空格
b. :include="[组件1, 组件2]"
c. :include="/^hello/"
2. exclude 排除
a. exclude=“组件1,组件2” 注意 逗号前后不要有空格
b. :exclude="[组件1, 组件2]"
c. :exclude="/^hello/"
3. max 规定大能缓存组件的数量,默认是没有限制的\
假定缓存队列是 [home, list]
现在进入about的时候 about 也会被缓存上,这时会将之前的第一个给排出去 [home, list, about] => [list, about] 先进先出原则。
概念就这些上代码
1.vue链接:https://cdn.jsdelivr.net/npm/vue@2.6.11/dist/vue.js
2.创建组件。(三个组件)
//组件一
Vue.component("home", {
data() {
return {
name: "张三",
};
},
template: `
home
{{ name }}
`,
//实例创建完成的时候打印
created() {
console.log("home created");
},
//实例销毁前的打印
beforeDestroy() {
console.log("home beforeDestroy");
},
//激活缓存的时候打印组件能被看到
activated() {
console.log("home activated");
},
//缓存失活时打印 组件不能被看到
deactivated() {
console.log("home deactivated");
},
});
//组件二
Vue.component("list", {
template: `
list
`,
//激活缓存的时候打印组件能被看到
created() {
console.log("list created");
},
//缓存失活时打印 组件不能被看到
beforeDestroy() {
console.log("list beforeDestroy");
},
});
//组件三
Vue.component("about", {
template: `
about
`,
//激活缓存的时候打印组件能被看到
created() {
console.log("about created");
},
//缓存失活时打印 组件不能被看到
beforeDestroy() {
console.log("about beforeDestroy");
},
});另外有需要云服务器可以了解下创新互联scvps.cn,海内外云服务器15元起步,三天无理由+7*72小时售后在线,公司持有idc许可证,提供“云服务器、裸金属服务器、高防服务器、香港服务器、美国服务器、虚拟主机、免备案服务器”等云主机租用服务以及企业上云的综合解决方案,具有“安全稳定、简单易用、服务可用性高、性价比高”等特点与优势,专为企业上云打造定制,能够满足用户丰富、多元化的应用场景需求。
网页题目:vue中keep-alive内置组件缓存的用法-创新互联
URL地址:http://www.scyingshan.cn/article/deepgs.html


咨询
建站咨询
