Vue-组件缓存-keep-alive

这篇具有很好参考价值的文章主要介绍了Vue-组件缓存-keep-alive。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

1. 介绍

在Vue.js中,组件的复用和缓存是一个重要的优化手段。当我们频繁切换组件时,频繁的销毁和重建会带来一定的性能开销。为了解决这个问题,Vue提供了一个名为keep-alive的抽象组件。下面我们将深入探讨keep-alive的工作原理、使用场景和最佳实践。

keep-alive是什么

  • keep-alive 是 Vue 的内置组件,当它包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。
  • keep-alive 是一个抽象组件:它自身不会渲染成一个 DOM 元素,也不会出现在父组件链中。

keep-alive的优点

  • 在组件切换过程中 把切换出去的组件保留在内存中,防止重复渲染DOM,
  • 减少加载时间及性能消耗,提高用户体验性。

2. Keep-Alive的工作原理

Keep-Alive组件主要用于缓存不活跃的组件实例,而不是销毁它们。当组件被包含在Keep-Alive内部时,它的状态(如数据、计算属性、生命周期钩子等)会被保留,而不是在每次切换时重新创建。当组件再次被切换到前台时,它的状态可以快速恢复,从而提高应用的整体性能。

3. 使用场景

  1. 频繁切换的页面组件:对于那些频繁切换的页面组件,如用户中心、设置等,使用Keep-Alive可以显著提高切换速度,减少不必要的渲染和计算。
  2. 列表渲染优化:当渲染大量列表数据时,频繁的DOM操作会消耗大量性能。通过使用Keep-Alive,我们可以缓存不活跃的列表项组件,从而减少不必要的DOM操作。
  3. 懒加载与预加载:结合Vue的异步组件和Keep-Alive,可以实现懒加载和预加载的效果,按需加载和缓存组件,进一步提高性能。

4. 使用方法

在Vue组件中,使用keep-alive标签包裹需要缓存的组件即可。例如:

<keep-alive>  
  <router-view></router-view>  
</keep-alive>

在这里,router-view用于渲染当前路由对应的组件视图。由于被包裹在keep-alive内,这些组件实例会被缓存起来,而不是每次切换时都重新创建。

5. keep-alive的三个属性

三个属性:

  • include : 组件名数组,只有匹配的组件会被缓存 - 比较常用
  • exclude : 组件名数组,任何匹配的组件都不会被缓存
  • max : 最多可以缓存多少组件实例

如下:

<keep-alive :include="[Layout,...]"> // 指定数组组件
  <router-view></router-view>
</keep-alive>

6. 特别说明

  1. 组件缓存后就不会执行组件的created, mounted, destroyed 等钩子了
  2. keep-alive的使用会触发两个生命周期函数 - 钩子
    • activated 当组件被激活(使用)的时候触发 → 进入这个页面的时候触发
    • deactivated 当组件不被使用的时候触发 → 离开这个页面的时候触发

如下:文章来源地址https://www.toymoban.com/news/detail-792984.html

activated () {
  console.log('actived 激活 → 进入页面');
},
deactivated() {
  console.log('deactived 失活 → 离开页面');
}

7. 注意事项

  1. 内存消耗:虽然Keep-Alive能够提高性能,但过度使用或不正确使用可能会导致不必要的内存消耗。应确保只在必要的情况下使用它。
  2. 数据一致性:由于组件状态会被保留,因此需要确保组件的数据在前后台切换时不会发生不一致的情况。在组件内部,需要合理处理数据的初始化和更新逻辑。
  3. 事件监听器与子组件引用:在使用Keep-Alive时,需要特别注意事件监听器和子组件引用的处理。因为组件实例会被缓存,之前绑定的事件监听器和子组件引用可能会继续存在,造成潜在的问题。正确处理这些情况是确保稳定性和性能的关键。

到了这里,关于Vue-组件缓存-keep-alive的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • Vue使用keep-alive设置哪些组件可以被缓存,哪些不被缓存

    需求:当一个项目中,不是所有的组件页面都需要缓存起来,因为有些页面是不需要的    $route.meta.keepAlive 判断当前组件是否有keepAlive属性 在路由js文件中在配置路由规则的时候配置  

    2024年02月16日
    浏览(41)
  • vue3,动态引入组件,同时动态设置组件的name,用于keep-alive缓存

    如果有两个页面逻辑大都相同,咱们想到的第一个肯定是写一个组件,然后两个路由都指向这个组件。 那如果现在多添加一个需求:两个页面在切换路由时都需要缓存数据,并且两个页面的缓存数据要求独立。 这个需求很简单:在router-view外层包裹一个keep-alive组件,指定缓

    2024年02月14日
    浏览(46)
  • keep-alive组件缓存

    从 a跳b,a已经销毁,b重新渲染;b跳a,b销毁a重新渲染 源组件销毁,目标组件渲染 组件缓存:组件实例等相关(  包括vnode )存储起来 重新渲染指的是:把视图重新编译成新的vnode-dom diff-渲染成真实dom 真实dom被我移除了只是从页面上移除,只是把vnode重新渲染成真实dom或者

    2024年01月21日
    浏览(40)
  • vue3,vite开发, 动态引入组件,同时动态设置组件的name,用于keep-alive缓存

    如果有两个页面逻辑大都相同,咱们想到的第一个肯定是写一个组件,然后两个路由都指向这个组件。 那如果现在多添加一个需求:两个页面在切换路由时都需要缓存数据,并且两个页面的缓存数据要求独立。 这个需求很简单:在router-view外层包裹一个keep-alive组件,指定缓

    2024年02月07日
    浏览(45)
  • 缓存滚动位置:解决keep-alive组件缓存滚动位置失败问题

    怎样在vue中缓存组件?大家都知道,使用keep-alive组件即可,但是使用keep-alive缓存页面后,发现虽然页面缓存成功了,但是列表的滚动条又自动回到了最上方。 是的, keep-alive组件是不会缓存滚动位置的 。 怎样缓存滚动位置呢?这是我们这一章讲的问题。 核心思想是在路由

    2024年02月16日
    浏览(44)
  • keep-alive 是 Vue 的一个内置组件,用于缓存其他组件的实例,以避免重复渲染和销毁,它可以在需要频繁切换的组件之间提供性能优化

    目录 keep-alive  使用 keep-alive 的示例代码: 手动清除组件缓存的示例代码: keep-alive 组件有以下几个优点: keep-alive 的原理: 使用 keep-alive 组件,你可以包裹需要缓存的组件,然后这些组件在切换时将会被缓存起来,而不是每次都重新创建。 使用 keep-alive 的示例代码: 我们

    2024年02月08日
    浏览(40)
  • VUE3,自定义控制keep-alive缓存

    安装插件 npm install vite-plugin-vue-setup-extend --save 在vite.config.ts中 import VueSetupExtend from \\\'vite-plugin-vue-setup-extend\\\' ..... plugins:[         vue(),         VueSetupExtend(),         ..... ] useKeepalive.ts import { ref } from \\\"vue\\\" export const includes = refstring[]([]); // 增加缓存 export function addKeepAliveC

    2024年01月19日
    浏览(36)
  • Vue3 除了 keep-alive,还有哪些实现页面缓存的方法

    有这么一个需求:列表页进入详情页后,切换回列表页,需要对列表页进行缓存,如果从首页进入列表页,就要重新加载列表页。 对于这个需求,我的第一个想法就是使用keep-alive来缓存列表页,列表和详情页切换时,列表页会被缓存;从首页进入列表页时,就重置列表页数

    2024年02月06日
    浏览(42)
  • react 实现页面状态缓存(keep-alive)

    因为 react、vue都是单页面应用,路由跳转时,就会销毁上一个页面的组件。但是有些项目不想被销毁,想保存状态。 比如:h5项目跳转其他页面返回时,页面状态不丢失。设想一个 页面我滑倒了中间,然后跳转到 详情页然后 返回,之前的页面刷新了,回到顶部了肯定不行(

    2024年01月23日
    浏览(44)
  • keep-alive缓存三级及三级以上路由

    需求:需要缓存这个出入记录,当tab切换时不重新加载,当刷新页面时,或把这个关闭在重新打开时重新加载如图: (我这里用的是芋道源码的前端框架) 1、include 包含页面组件name的这些组件页面,会被缓存起来 2、exclude 除了这些name以外的页面组件,会被缓存起来 3、没有

    2024年02月09日
    浏览(42)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包