关于vue keep-alive用法的总结

是Vue的内置组件,能在组件切换过程中将状态保留在内存中,防止重复渲染DOM。
用法1:include(包含): 字符串或正则表达式。只有匹配的组件会被缓存。
exclude(除了): 字符串或正则表达式。任何匹配的组件都不会被缓存。

// 组件
export default {
  name: 'test-keep-alive',
  data () {
    return {
        includedComponents: "test-keep-alive"
    }
  }
}
<keep-alive include="test-keep-alive">
  <!-- 将缓存name为test-keep-alive的组件 -->
  <component></component>
</keep-alive>

<keep-alive include="a,b">
  <!-- 将缓存name为a或者b的组件,结合动态组件使用 -->
  <component :is="view"></component>
</keep-alive>

<!-- 使用正则表达式,需使用v-bind -->
<keep-alive :include="/a|b/">
  <component :is="view"></component>
</keep-alive>

<!-- 动态判断 -->
<keep-alive :include="includedComponents">
  <router-view></router-view>
</keep-alive>

<keep-alive exclude="test-keep-alive">
  <!-- 将不缓存name为test-keep-alive的组件 -->
  <component></component>
</keep-alive>

用法2:可以动态配置路由,来确定那些路由需要缓存哪些不需要缓存,这样的话就需要修改route文件下的index.js文件:

export default new Router({
  routes: [
    {
      path: '/',
      name: 'Hello',
      component: Hello,
      meta: {
        keepAlive: false // 不需要缓存
      }
    },
    {
      path: '/page1',
      name: 'Page1',
      component: Page1,
      meta: {
        keepAlive: true // 需要被缓存
      }
    }
  ]
})
<keep-alive>
    <router-view v-if="$route.meta.keepAlive"></router-view>
</keep-alive>
<router-view v-if="!$route.meta.keepAlive"></router-view>

2.1特殊需求:
首页是A页面
B页面跳转到A,A页面需要缓存
C页面跳转到A,A页面不需要被缓存
(例:详情跳列表,首页跳列表)

{
    path: '/',
    name: 'A',
    component: A,
    meta: {
        keepAlive: true // 需要被缓存
    }
}

2.1.1第一种写法

router.beforeEach((to, from, next) => {
  // console.log(to.path,'to...');
  // console.log(from.path,'from...');
  //判断是否需要缓存
    if(to.path == '/a' && from.path == '/b'){
      to.meta.keepAlive = true;  // 让 首页 缓存,即不刷新
      next();
    }else {
      to.meta.keepAlive = false;  // 让 列表页 即不缓存,刷新
      next();
    }
})

2.1.2第二种写法

export default {
    data() {
        return {};
    },
    methods: {},
    beforeRouteLeave(to, from, next) {
         // 设置下一个路由的 meta
        to.meta.keepAlive = true;  // B 跳转到 A 时,让 A 缓存,即不刷新(有类型的列表也可以运用缓存,返回到上一步指定的类型)
        next();
    }
};
export default {
    data() {
        return {};
    },
    methods: {},
    beforeRouteLeave(to, from, next) {
        // 设置下一个路由的 meta
        to.meta.keepAlive = false; // C 跳转到 A 时让 A 不缓存,即刷新
        next();
    }
};

keep-alive后的生命周期
生命周期执行顺序:
1、不使用keep-alive的情况:
beforeRouteEnter --> created --> mounted --> destroyed
2、使用keep-alive,第一次进入的情况:
beforeRouteEnter --> created --> mounted --> activated --> deactivated
3、使用keep-alive,再次进入了缓存页面的情况:
beforeRouteEnter -->activated --> deactivated

keep-alive生命周期钩子函数:activated、deactivated
使用会将数据保留在内存中,如果要在每次进入页面的时候获取最新的数据,需要在activated阶段获取数据,承担原来created钩子中获取数据的任务。

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vuekeep-alive 组件是用来缓存具有相同组件名称的组件的,例如在一个 Tab 页中不同的 Tab 相互切换时,当前 Tab 中的组件及其状态可以被 keep-alive 缓存,以避免在该 Tab 内重复加载组件和数据。 源码中实现了两个生命周期方法 activate() 和 deactivate() 来控制缓存中的组件的挂载和卸载。缓存中的组件通过 mount() 方法来挂载,并在 activated 钩子函数中调用 vnode 的 activated 钩子函数和组件的 activated 钩子函数。 当组件被激活(activated)时,keep-alive 会调用 activate() 方法,该方法会检查被缓存组件的缓存状态,并通过缓存对象的 updated 标志来决定组件是否需要重新挂载。如果需要重新挂载,则通过缓存对象的 vnode 函数重新渲染组件,并调用新组件的 mounted 和 activated 钩子函数。 当组件被停用(deactivated)时,keep-alive 会调用 deactivate() 方法,该方法会调用被缓存组件的 deactivated 钩子函数,并通过 VNode 的 tag 属性判断组件是否需要被销毁。如果不需要被销毁,则缓存对象会记录其销毁状态并保留其状态,下次使用时可以快速还原组件。如果需要被销毁,则通过调用缓存对象的 destroy() 方法来销毁组件并释放资源。 总之,Vue keep-alive 组件通过缓存组件的方式来提高应用程序的性能和用户体验,实现了快速切换和缓存组件的功能。它的核心在于更新缓存中的组件,并且在组件被激活和停用时触发生命周期函数来维护组件的状态。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值