vue跳转页面后返回不刷新且记录历史滚动条停留位置 (实现了根据不同页面来设置是否刷新记录的功能)

文章介绍了在Vue.js应用中如何配置路由和使用`keep-alive`来实现页面返回时不刷新,并通过在`beforeRouteLeave`和`activated`钩子中保存及恢复滚动条位置,从而达到滚动条记忆的效果。同时,通过全局变量`isRefresh`判断是否需要刷新组件数据,确保在特定情况下能更新列表内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、页面返回后不刷新

        1.在路由(router/index.js)中,对不刷新的页面设置:

meta: {
        keepAlive: true    //true为需要缓存,false为不需要缓存(不需要的也可以不加)
      },

        2.在app.vue中设置:

<div id="app">
    <keep-alive>
      <router-view v-if="$route.meta.keepAlive"></router-view>
    </keep-alive>
    <router-view v-if="!$route.meta.keepAlive"></router-view>
  </div>

这时返回就不会触发created和mounted

二、记录滚动条位置,并在页面显示时设置它:

        1.在data中定义

scrollTop: 0,

        2.挂载:

    //离开路由之前执行的函数,可用于页面的反向传值,页面跳转。
    beforeRouteLeave(to, from, next) {
      console.log("1212-beforeRouteLeave")
      // 记录滚动条位置
      this.scrollTop = document.documentElement.getElementsByClassName("itemBoxs")[0].scrollTop || 0; //组件写法
      this.scrollTop = document.documentElement.getElementById('app').scrollTop || 0; //全局写法
      console.log("this.scrollTop", this.scrollTop)
      next()
    },
    // 组件激活时触发
    activated() {
      // 还原滚动条位置
      console.log("1212-activated")
      document.getElementsByClassName("itemBoxs")[0].scrollTop = this.scrollTop || 0; //组件写法
      document.getElementById('app').scrollTop = this.scrollTop || 0; //全局写法
    },

以上就实现了返回页面后滚动条记忆的功能啦!

如果想实现分情况决定是否记忆滚动条以及刷新组件数据,请继续往下看:

在上述keep-alive的基础上

1.定义全局变量(不要在data中定义!!!)

var isRefresh = false; //定义是否需要刷新

注: 之所以在定义全局变量isRefresh而不在data里定义是因为当生命周期进入beforeRouteEnter的时候,此时当前页面还没有被mounted,因此我们是获取不到当前实例this的指向的,变量值也取不到。

2.定义beforeRouteEnter

 //路由进入前判断是否重新加载还是缓存
  beforeRouteEnter(to, from, next){
    if(from.name == 'textbookModeSelection'){ //哪个页面 进入需要刷新
      isRefresh = true; //需要刷新
    }else{
      isRefresh = false;
    }
    next()
  },

3.定义activated

// 组件激活时触发
  activated() {
    if(isRefresh) {
      //刷新
      this.chooseCourseIndex = null; //清空需要的数据
      document.getElementsByClassName("itemBoxs")[0].scrollTop = 0; //置顶滚动条
      this.init(); //调用获取数据方法
    }else{
      //不刷新  还原滚动条位置
    document.getElementsByClassName("itemBoxs")[0].scrollTop = this.scrollTop || 0;
    }

注: keep-alive之后不会执行created,mounted钩子了,在activated中判断需要刷新之后,将列表数据初始化,发起请求即可,不刷新时则返回到列表记录的滚动条的位置

4.定义beforeRouteLeave

//路由离开前执行
beforeRouteLeave(to, from, next) {
    // 记录滚动条位置
    this.scrollTop = document.documentElement.getElementsByClassName("itemBoxs")[0].scrollTop || 0;
    next()
  },

完成!

Vue项目中,当用户通过页面跳转离开当前页面,然后再返回时,通常希望能够回到离开前的滚动位置。为了实现这一功能,我们可以利用Vue的状态管理工具Vuex来记录和恢复滚动位置。以下是具体的实现步骤: 参考资源链接:[vue页面跳转返回页面初始位置方法](https://wenku.csdn.net/doc/6412b49ebe7fbd1778d40387?spm=1055.2569.3001.10343) 1.Vue项目中引入并使用Vuex库。首先,在`main.js`文件中安装并引入Vuex,并使用Vue.use()方法注册Vuex。 ```javascript import Vue from 'vue' import Vuex from 'vuex' Vue.use(Vuex) ``` 2. 创建Vuex存储并初始化状态。在`main.js`中,创建一个新的Vuex Store实例,并在state中定义一个用于存储滚动位置的属性。 ```javascript const store = new Vuex.Store({ state: { scrollY: 0 // 初始滚动位置设置为0 } }) ``` 3.页面跳转前保存滚动位置。在触发跳转的事件处理函数中,将当前的滚动位置保存到Vuex状态中。 ```javascript methods: { goToPage() { // 保存当前滚动位置 this.$store.state.scrollY = window.scrollY; // 页面跳转逻辑 // ... } } ``` 4.页面返回后恢复滚动位置。在页面加载完毕后,将之前保存的滚动位置设置为body的滚动位置。 ```javascript mounted() { // 恢复之前保存的滚动位置 window.scrollTo(0, this.$store.state.scrollY); } ``` 通过以上步骤,即可实现Vue项目中页面跳转后自动返回之前的滚动位置。这种方法主要利用了Vuex的持久化存储特性,确保了即使页面刷新,滚动位置信息也能被保留。 参考资源链接:[vue页面跳转返回页面初始位置方法](https://wenku.csdn.net/doc/6412b49ebe7fbd1778d40387?spm=1055.2569.3001.10343)
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值