VUE 实现滚动条定位以及返回上一页,滚动条固定在原来位置

本文介绍了一种在网页滚动位置进行保存和恢复的方法。通过监听滚动事件并将滚动位置存储到本地存储中,再利用Vue的watch和nextTick函数,在页面重新加载时精确恢复到之前的滚动位置。这一技巧对于提升用户体验,特别是在长页面或复杂应用中非常有用。
//1.获取滚动条的位置,并存到缓存里
<script>
    document.onscroll = function(){
        getScrollTop()
    }
    function getScrollTop(){
        var scrollTop=0;
        if(document.documentElement&&document.documentElement.scrollTop){
            scrollTop=document.documentElement.scrollTop;
        }else if(document.body){
            scrollTop=document.body.scrollTop;
        }
        localStorage.setItem('position_data',scrollTop);
    }
</script>


//2.渲染完页面,从缓存里取出滚动条的位置:运用了vue的watch和nextTick函数,missionData是数据
    watch:{
            missionData: function(){
                this.$nextTick(() => {
                    console.log(localStorage.getItem('position_data'))
                    window.scrollTo(0, parseInt(localStorage.getItem('position_data')))
                })
            }
        }

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值