VUE3,页面加了 keepAlive 之后 table 组件的 v-loading 失效 - V2EX
V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
请不要在回答技术问题时复制粘贴 AI 生成的内容
coollest
V2EX    程序员

VUE3,页面加了 keepAlive 之后 able 组件的 v-loading 失效

  •  
  •   coollest 2024-09-26 16:21:24 +08:00 1784 次点击
    这是一个创建于 387 天前的主题,其中的信息可能已经有所发展或是发生改变。

    App.vue 里边的代码是

    <el-main class="container"> <router-view v-slot="{ Component }"> <keep-alive v-if="$route.meta.keepAlive"> <component :is="Component" :key="$route.path" /> </keep-alive> <component :is="Component" :key="$route.path" v-else/> </router-view> </el-main> 

    页面中只在 table 组件上加了 v-loading ,请求数据前设置为 true ,得到数据后为 false 。现在的问题是第一次进

    入页面加载数据时,table 会直接显示 no data ,而不是 loading 转圈。各位大佬有遇到过这个问题吗,求教。

    第 1 条附言    2024-09-27 09:46:17 +08:00

    最后问题解决了用的是服务的方式调用v-loading

    import { ElLoading } from 'element-plus' // 取数据之前调用 const loadingInstance = ElLoading.service({fullscreen: true}) // 结束时关闭 loadingInstance.close() 
    10 条回复    2024-09-27 13:13:06 +08:00
    Happy66606
        1
    Happy66606  
       2024-09-26 16:26:35 +08:00
    这是因为 `keep-alive` 缓存了组件的状态,当你再次进入页面时,组件不会被重新渲染,而是直接从缓存中取出之前的状态。因此,`v-loading` 的状态也不会被重新设置。

    你可以尝试在组件的 `activated` 生命周期钩子中手动设置 `v-loading` 的状态。例如:

    ```Javascript
    activated() {
    this.loading = true;
    // ... 请求数据 ...
    }
    ```

    或者,你可以使用 `keep-alive` 的 `include` 属性来排除某些组件不被缓存。例如:

    ```html
    <keep-alive :include="['Home', 'About']">
    <!-- ... -->
    </keep-alive>
    ```

    这样,`table` 组件就不会被缓存,`v-loading` 的状态就会被正常设置。

    另外,你也可以尝试使用 `v-if` 来控制 `table` 组件的渲染,例如:

    ```html
    <table v-if="!loading" v-loading="loading">
    <!-- ... -->
    </table>
    ```

    这样,当 `loading` 为 `true` 时,`table` 组件就不会被渲染。
    coollest
        2
    coollest  
    OP
       2024-09-26 16:35:14 +08:00
    @Happy66606 感谢大佬,我试了一下 activated 钩子的方法,好像还是不太行啊,就是请求完一次数据之后,组件被缓存,第二次进入也没有 loading 的这个问题。现在就是第一次进入页面,v-loading 还是不生效。再次感谢!我再自己研究一下
    fishlium
        3
    fishlium  
       2024-09-26 16:46:21 +08:00
    你的数据加载写在什么地方的
    coollest
        4
    coollest  
    OP
       2024-09-26 16:48:02 +08:00
    @fishlium 写在 onBeforeMount 钩子里的
    fishlium
        5
    fishlium  
       2024-09-26 17:43:33 +08:00
    @coollest 你写 onMounted()的试试
    coollest
        6
    coollest  
    OP
       2024-09-27 08:45:58 +08:00
    @fishlium 昨晚忘了回复了,还是不行。但是还是谢谢大佬!
    fishlium
        7
    fishlium  
       2024-09-27 08:54:31 +08:00
    @coollest 你把 v-if 换到 component 上试试呢
    coollest
        8
    coollest  
    OP
       2024-09-27 09:10:12 +08:00
    @fishlium 昨晚发现这个问题了,如果按照帖子里的写法 keepAlive 就直接失效了,放在 component 上才能正常生效。但是还是没有 loading 的效果
    0xD800
        9
    0xD800  
       2024-09-27 12:06:19 +08:00
    有复现 demo 吗 用 setTimeout 模拟数据请求
    coollest
        10
    coollest  
    OP
       2024-09-27 13:13:06 +08:00
    @0xD800 差不多是这样的

    <script lang="ts" setup>
    import axios from 'axios';
    import { ElLoading } from 'element-plus'
    import { onMounted } from 'vue';
    let loadingInstance:any = null

    function getData() {
    let res:any = axios.post('xxx')
    if (res && res.success) {
    loadingInstance.close()
    } else {
    //报错提示
    loadingInstance.close()
    }
    }
    onMounted(() => {
    loadingInstance = ElLoading.service({fullscreen: true})
    //请求数据
    getData()
    })
    </script>
    关于     帮助文档     自助推广系统     博客     API     FAQ     Solana     最高记录 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 28ms UTC 21:30 PVG 05:30 LAX 14:30 JFK 17:30
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86