keep-alive指定缓存或不缓存某些组件时不生效

文章讲述了在Vue应用中遇到的keep-alive组件缓存问题,即如何确保只有需要缓存的部分组件被正确地缓存。关键在于组件内部的name属性,如果组件有name,则include中应使用相同的名称;如果没有,需使用引入时的组件名称。
摘要由CSDN通过智能技术生成

目录

一、问题

二、解决方法

三、总结


tiips:如嫌繁琐,直接移步总结即可!

一、问题

1.有些页面的数据加载太慢了,需要缓存;而有些地方需要实时调用接口才能够拿到最新的数据;甚至有些地方需要另外一个缓存的数据才能调用接口获取数据。

二、解决方法

1.keep-alive可以缓存组件,可是我有些地方需要缓存,有些地方不需要缓存。怎么办呢?百度了半天,毫无头绪。看到include属性,添加后发现依然无效。

2.不得不去官网看看,到底是怎么用的。

3.官网是这样写的:提供include属性时,只有与include名称匹配的组件会被缓存。

4.我真的很纳闷呀,我也是这样写的,怎么不起作用呢?我也是这样写的呀。。。。。

<template>
  <keep-alive :include="'EditNurse'">
    <component is="currentComponent"> </component>
  </keep-alive>
</template>
<script>
import { defineComponent, toRefs, ref, computed, watch, getCurrentInstance, onMounted, reactive } from 'vue';
import EditNurse from './EditTemplate.view';
export default defineComponent({
  components: {
    EditNurse
  },
  setup() {
    const currentComponent = ref('EditNurse');
    return {
      currentComponent
    };
  }
});
</script>

5.组件名称?好像组件都有一个name属性,试试在 EditNurse组件中加一个name说不定可以。。。看了一下EditNurse组件发现已经有name: 'EditTemplate',了,把上面include换成 EditTemplate就好了。

<template>
  <keep-alive :include="'EditTemplate'">
    <component is="currentComponent"> </component>
  </keep-alive>
</template>
<script>
import { defineComponent, toRefs, ref, computed, watch, getCurrentInstance, onMounted, reactive } from 'vue';
import EditNurse from './EditTemplate.view';
export default defineComponent({
  components: {
    EditNurse
  },
  setup() {
    const currentComponent = ref('EditNurse');
    return {
      currentComponent
    };
  }
});
</script>

6.然后我意识到怎么会这么无厘头呢,为啥引入的组件要换名称呢?就算引入的时候换了名称,对应的组件name不应该也相应修改吗?

7.测试了一下两种情况

1)EditTemplate组件内部不显示指定   name: 'EditTemplate', 引入组件后重命名为 EditNurse,直接使用 4中的代码:

:include="'EditNurse'"是正确的,组件EditTemplate可以被缓存。

:include="'EditTemplate'"是错误的,组件EditTemplate不可以被缓存。

结论:组件内部没有显示提供name时,引入的时候名称是什么,则组件的name就是什么。

2)引入后的组件名称和引入前一样EditTemplate。include的时候当然也是用的EditTemplate,正确,可以被缓存。

<template>
  <keep-alive :include="'EditTemplate'">
    <component is="currentComponent"> </component>
  </keep-alive>
</template>
<script>
import { defineComponent, toRefs, ref, computed, watch, getCurrentInstance, onMounted, reactive } from 'vue';
import EditTemplate from './EditTemplate.view';
export default defineComponent({
  components: {
    EditTemplate
  },
  setup() {
    const currentComponent = ref('EditTemplate');
    return {
      currentComponent
    };
  }
});
</script>

8.最终结论:原始组件内部没有指明 name时,引入的时候叫什么名字,则在当前文件下面该组件的name就是什么。 原始组件内部有name时,无论你引入后交什么名字,在当前文件下面该组件的name都是原始组件中的name。

三、总结

1.keep-alive include不生效请检查原始组件内部是否显示声明 name如果有,则include中的内部必须是原始组件中的name;如果没有,则你引入组件的时候叫什么名称,include中就使用什么名称。

//1.原始组件B有name

import A from './B.vue';

B组件: name:'componentB'

:include="'componentB'"

//2.原始组件B没有name

import A from './B.vue';

:include="'A'"

2.exclude属性也是和上面的include属性一样的!

3.诶,天天采坑,是祸也是福,解决了就是福!

/*

希望对你有帮助!

如有错误,欢迎指正,非常感谢!

*/

  • 25
    点赞
  • 18
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Vue.js 中,`<keep-alive>` 可以用来缓存组件,以便在组件之间切换保留它们的状态。如果你发现 `<keep-alive>` 缓存不起作用,可能是因为以下原因: 1. 没有正确配置 `key` 属性 `<keep-alive>` 缓存组件是根据组件的 `key` 属性来进行匹配的。如果组件没有设置 `key` 属性,那么 `<keep-alive>` 就无法缓存组件。因此,在使用 `<keep-alive>` ,确保每个组件都有一个唯一的 `key` 属性。 2. 缓存组件没有被销毁 如果你发现 `<keep-alive>` 缓存组件不生效,可能是因为缓存组件没有被销毁。在切换组件,如果前一个组件没有被销毁,那么它就不会被缓存。因此,在使用 `<keep-alive>` ,确保在组件销毁清理相关的状态和数据。 3. 禁用了缓存 在某些情况下,可能需要禁用缓存。例如,当组件的状态需要在每次切换都重新加载,就需要禁用缓存。在这种情况下,只需要在 `<keep-alive>` 标签上添加 `include="none"` 属性即可禁用缓存。 下面是一个简单的示例,展示了如何正确地使用 `<keep-alive>`: ``` <template> <div> <button @click="toggle">Toggle</button> <keep-alive> <component :is="componentName" :key="componentKey"></component> </keep-alive> </div> </template> <script> export default { data() { return { componentName: 'ComponentA', componentKey: 0, }; }, methods: { toggle() { this.componentName = this.componentName === 'ComponentA' ? 'ComponentB' : 'ComponentA'; this.componentKey++; }, }, }; </script> ``` 在上面的示例中,我们在 `<component>` 标签中使用了 `:key="componentKey"` 来确保每个组件都有一个唯一的 `key` 属性。在 `toggle` 方法中,我们切换了两个组件,并且每次切换都增加了 `componentKey` 的值。这样,我们就可以确保每个组件都有一个唯一的 `key` 属性,并且 `<keep-alive>` 可以正确地缓存组件
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值