vue 路由跳转记住滚动位置,返回时回到上次滚动位置

方法一: 利用Keep-Alive和监听器
1.首先在路由中引入需要的模块

{ 
    path:/scrollDemo’, 
    name: ‘scrollDemo’, 
    meta: { 
        keepAlive: true // 需要缓存 
    }, 
    component: resolve => { require([../view/scrollDemo.vue’], resolve) } 
}    

2.在App.vue中设置缓存组件

<keep-alive>   // 缓存组件跳转的页面
   <router-view v-if="$route.meta.keepAlive" class="ui-view"  transition-mode="out-in"></router-view>
 </keep-alive>  
  // 非缓存组件跳转页面
 <router-view v-if="!$route.meta.keepAlive" class="ui-view"  transition-mode="out-in"></router-view>

3.在页面注册对应的事件

(1). 在data中定义一个初始值 scroll

(2). 在mouted中 ,mouted中的方法代表dom已经加载完毕

window.addEventListener('scroll', this.handleScroll);

(3).methods 用于存放页面函数

handleScroll () {
		//document.documentElement.scrollTop获取当前页面的滚动条纵坐标位置
       this.scroll  = document.documentElement && document.documentElement.scrollTop
       console.log(this.scroll)
}    

4.activated 为keep-alive加载时调用

activated() {
    if(this.scroll > 0){
        window.scrollTo(0, this.scroll);//可把内容滚动到指定的坐标
        this.scroll = 0;
        window.addEventListener('scroll', this.handleScroll);
     }
}

5.deactivated 页面退出时关闭事件 防止其他页面出现问题

deactivated(){
     window.removeEventListener('scroll', this.handleScroll);
}

方法二:利用beforeRouteLeave和watch
main.js中:

var store = new Vuex.Store({   //记得先引入vuex
    state: {
        recruitScrollY: 0
    },
    getters: {
        recruitScrollY: state => state.recruitScrollY
    },
    mutations: {
        changeRecruitScrollY(state, recruitScrollY) {
            state.recruitScrollY = recruitScrollY;
        }
    },
    actions: {

    },
    modules: {}
})

组件中(/flashSaleListX为当前组件,即需要记住滚动条位置的组件):

methods:{
      isTabRoute: function() {
            if (this.$route.path === '/flashSaleListX') {
                  let recruitScrollY = this.$store.state.recruitScrollY
                  document.documentElement.scrollTop = recruitScrollY;
            }
      }
},
watch: {
             '$route': 'isTabRoute',
},
beforeRouteLeave(to, from, next) {
      let position = document.documentElement && document.documentElement.scrollTop; //记录离开页面时的位置

      if (position == null) position = 0
      this.$store.commit('changeRecruitScrollY', position) //离开路由时把位置存起来
      next()
}

方法三:(适用于方法二获取不到滚动位置)
组件中:

<template>
  <div ref="div1">
  ··· 内容···
  </div>
</template>
beforeRouteEnter(to, from, next) {
   next(vm => {
     const div1 = vm.$refs.div1
     // 记录滚动高度
     div1.scrollTop = vm.scroll
   })
},
beforeRouteLeave(to, from, next) {
   const div1 = this.$refs.div1;
   this.scroll = div1.scrollTop; //data中记得定义变量scroll
   next()
}

注:在路由配置中,记住滚动的页面keep-alive需为true

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vue中,当使用前端由切换到新的,默认情况下滚动条会被重置到页面顶部,不会保持原先的滚动位置。如果你想要在由切换滚动条置顶,你可以通过自定义由切换滚动行为来实现。在由配置中,可以使用scrollBehavior函数来自定义滚动行为。scrollBehavior函数接收三个参数:to(目标由对象)、from(来源由对象)和savedPosition(之前的滚动位置)。你可以根据这些参数来自定义滚动行为。如果你想让滚动条在由切换置顶,你可以在scrollBehavior函数中返回{ x: 0, y: 0 }来将滚动位置重置为页面顶部。这样,在每次由切换,页面都会滚动到顶部。这就是如何在Vue中实现滚动条置顶的方法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue 切换由页面滚动滚动到最上面](https://blog.csdn.net/xingchen678/article/details/128723182)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [vue滚动 切换由之后滚动条在最上面](https://blog.csdn.net/m0_64415782/article/details/131938991)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值