• Vue-3.1缓存组件keep-alive


    问题:从首页卡片点到详情页,又点返回,数据重新加载了->希望回到原来的位置

    原因:路由跳转后,组件被销毁了,返回回来组件又被重建了,所以数据重新被加载了

    解决:利用keep-alive将组件缓存下来

    keep-alive是什么

    keep-alive是Vue的内置组件,当它包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们。

    keep-alive是一个抽象组件:它自身不会渲染成一个DOM元素,也不会出现在父组件链中,只是一个容器。

    keep-alive的优点

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

    1. <template>
    2. <div class="h5-wrapper">
    3. <keep-alive>
    4. <router-view></router-view>
    5. </keep-alive>
    6. </div>
    7. </template>

    问题:缓存了所有被切换的组件

    keep-alive是三个属性

    1)include:组件名数组,只有匹配的组件会被缓存

    2)exclude:组件名数组,任何匹配的组件都不会被缓存

    3)max:最多可以缓存多少组件实例

    1. <template>
    2. <div class="h5-wrapper" :include="['LayoutPage']">
    3. <keep-alive>
    4. <router-view></router-view>
    5. </keep-alive>
    6. </div>
    7. </template>

    组件名:name命名的,如果没有配置name,才会找文件名作为组件名

    被缓存的组件会多两个生命周期钩子

    1)actived:激活时,组件被看到时触发->进入页面时触发

    2)deactived:失活时,组件看不见时触发->离开页面时触发

    组件缓存了,就不会执行组件的created、mounted、destroyed等钩子,所以提供了actived和deactived

  • 相关阅读:
    缺失的数据范围,思维,hduoj
    如何为视频添加旁白,有哪些操作技巧?
    Go1.20 新版覆盖率方案解读
    python函数的定义及使用
    【UOJ 454】打雪仗(通信题)(分块)
    【Linux】基本指令-入门级文件操作(一)
    如何驾驭ChatGPT:掌控有效对话!
    pdf合并(python)
    《Orange‘s 一个操作系统的实现》第七章
    前端JS算法--快速排序
  • 原文地址:https://blog.csdn.net/weixin_46479909/article/details/133846416