需求:
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: `
<div>
<h1>home</h1>
<p>{{ name }}</p>
<button @click="name = '李四'">修改name为 李四</button>
</div>
`,
//实例创建完成的时候打印
created() {
console.log("home created");
},
//实例销毁前的打印
beforeDestroy() {
console.log("home beforeDestroy");
},
//激活缓存的时候打印组件能被看到
activated() {
console.log("home activated");
},
//缓存失活时打印 组件不能被看到
deactivated() {
console.log("home deactivated");
},
});
//组件二
Vue.component("list", {
template: `
<div>
<h1>list</h1>
</div>
`,
//激活缓存的时候打印组件能被看到
created() {
console.log("list created");
},
//缓存失活时打印 组件不能被看到
beforeDestroy() {
console.log("list beforeDestroy");
},
});
//组件三
Vue.component("about", {
template: `
<div>
<h1>about</h1>
</div>
`,
//激活缓存的时候打印组件能被看到
created() {
console.log("about created");
},
//缓存失活时打印 组件不能被看到
beforeDestroy() {
console.log("about beforeDestroy");
},
});
3.创建实例。
Vue.component("home", {
data() {
return {
name: "张三",
};
},
body部分
<div id="app">
//active是样式来做高亮用v-bind来绑定
//@click自定义事件将实例里的数据改为home
//点击的时候会触发component内置标签更换为home
<button :class="{ active: curPage === 'home' }" @click="curPage = 'home'">
home
</button>
<button :class="{ active: curPage === 'list' }" @click="curPage = 'list'">
list
</button>
<button
:class="{ active: curPage === 'about' }"
@click="curPage = 'about'"
>
about
</button>
<hr />
//用keep-alive内置组件包裹componet内置组件v-bind绑定max作用是最多缓存两个
<keep-alive :max="2">
<component :is="curPage"></component>
</keep-alive>
//方法二
//排除法排除了about只有home与list可以缓存
//<keep-alive exclude="about">
// <component :is="curPage"></component>
//</keep-alive>
//方法三
//选择缓存法只有home与list可以被缓存
//keep-alive include="home,list">
//<component :is="curPage"></component>
//</keep-alive>
</div>
三种方法的具体用法在文章的开始的时候有介绍
总结
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。