码迷,mamicode.com
首页 > 其他好文 > 详细

7.Vue_____keep-alive(结合路由)

时间:2020-06-14 01:32:25      阅读:69      评论:0      收藏:0      [点我收藏+]

标签:获取   include   router   通过   匹配   钩子   ali   数据保存   text   

1、keep-alive这个内置组件,因为会把数据保存到内存中,所以不会销毁组件也不会重新渲染组件
通过路由切换组件得话组件是不会被从新销毁和渲染得

2、因为本身keep-alive可以实现缓存
告诉keep-alive要缓存那个组件中得数据
属性值得值都是正则表达式(匹配得组件数据才会缓存)或字符串(只缓存当前组件中得数据)
include:需要缓存谁
exclude:不缓存谁

3、当使用keep-alive得时候,因为组件是被存放在内存中的,所以不会触发created钩子函数,也就意味着不能再这个钩子函数中获取数据等得一系列操作
这个时候可以使用keep-alive得钩子函数来实现,activated(是再进入这个组件时触发得)和deactivated(是再离开这个组件时触发得)

例:

//父亲
<template> <div id=app> <div> <router-link to="/">Home</router-link> <router-link to="/about">about</router-link> </div> <keep-alive include="Home"> <router-view></router-view> </keep-alive> </div> </template> <script> export default { name: App, } </script>
 //home组件

<template>
    <div>
        我是home
        <input type="text">
    </div>
</template>

<script>
export default {
    name:‘Home‘,
     beforeDestroy () {
         console.log("home 销毁")
     },
       activated () {
          console.log("你来了") 
     },
     deactivated () {
       console.log("nizoule1")
     }
}
</script>
//about组件

<template>
    <div>
        我是abuot
         <input type="text">
    </div>
</template>

<script>

export default {
    name:‘About‘,
      beforeDestroy () {
         console.log("about销毁")
     }
}
</script>

 

7.Vue_____keep-alive(结合路由)

标签:获取   include   router   通过   匹配   钩子   ali   数据保存   text   

原文地址:https://www.cnblogs.com/taozhibin/p/13122253.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!