项目场景:路由跳转使用KeepAlive保存状态及高度

解决方案:

1.首先需要配置一下keep-alive

第一种方式:

 <router-view v-slot="{ Component }">
          <keep-alive include="Coupe,CoupeDetail">
           <component :is="Component"></component>
          </keep-alive>
 </router-view>

第二中方式:需要在目标路由添加一个meta属性

<keep-alive>
    <router-view v-if="$route.meta.KeepAlive"/>
</keep-alive>

<router-view v-if="!$route.meta.KeepAlive"/>

配置上keepAlive就可以实现状态的保存。

2.目标组件写代码

1.使用ref获取dom,或者使用js直接获取dom
2.keepAlive存在两个生命周期钩子,配合钩子实现代码

<div class="article_list" @scroll="scrollEvent($event)" ref="articleList"><div>
<script setup>
import { ref, toRefs,onActivated,onDeactivated,onMounted } from "vue";
const scrollTop = ref("");
const articleList = ref(null)
	onActivated(() => {
        console.log("子组件");
        articleList.value.scrollTop = scrollTop.value;
    });
	onDeactivated(() => {
        console.log("离开 ...");
    });
    function handlerScroll() {
      scrollTop.value = articleList.value.scrollTop;
        console.log(articleList.value.scrollTop, "778");
    }
    const scrollEvent = debounce(handlerScroll,500)
</script>

即可实现

如果说有需求是 二级子路由跳转到一级路由时,keepAlive可能会失效,需要将当前二级子路由的父路由注册keepAlive

Logo

前往低代码交流专区

更多推荐