vue3+ts 记录滚动条的位置

文章介绍了如何在Vue应用中,利用sessionStorage存储和在路由切换时恢复列表组件的滚动位置,以提供连续的用户体验。

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

想要的效果是这样的

用的方法很简单,就是sessionStorage存储,下面是代码

路由部分

import {createRouter,createWebHistory,RouteRecordRaw} from 'vue-router'


const routes:Array<RouteRecordRaw>=[
    {
        path:'/',
        component:()=>import('../views/home.vue')
    },
    {
        path:'/about',
        component:()=>import('../views/about.vue')
    }
]

export default createRouter({
    history:createWebHistory(),
    routes
})

home组件

<template>
    <p>home</p>
    <ul ref="scrollRef" @scroll="handleScroll">
        <li v-for="item in list">
            {{ item }}
        </li>
    </ul>
    <button @click="about">去关于</button>
</template>

<script setup lang="ts">
    import {useRouter} from 'vue-router'
    import {onBeforeUnmount,onMounted,reactive,ref} from 'vue'

    const router=useRouter()

    const list=reactive([1,2,3,4,5,6,7,8,9,10])
    const scrollRef=ref<any>(null)

    const about=()=>{
        router.push('/about')
    }
    const handleScroll=(e:any)=>{
        sessionStorage.setItem('currentPageScroll',JSON.stringify(e.target.scrollTop))
    }   

    onMounted(()=>{
       scrollRef.value.scrollTop=JSON.parse(sessionStorage.getItem('scroll') as string) || 
       scrollRef.value.scrollTop===0?JSON.parse(sessionStorage.getItem('currentPageScroll') as string):0
    })
    onBeforeUnmount(()=>{
        sessionStorage.setItem('scroll',JSON.stringify(scrollRef.value.scrollTop))
    })
    
</script>

<style scoped lang="scss">
    ul{
        list-style: none;
        border: 1px solid black;
        height: 200px;
        overflow: auto;
        padding-left: 0;
        li{
            height: 50px;
            line-height: 50px;
            border-bottom: 1px solid #000;
        }
    }
</style>

about组件

<template>
    <p>about</p>
    <button @click="home">去首页</button>
</template>

<script setup lang="ts">
    import { useRouter } from 'vue-router'
    const router=useRouter()

    const home=()=>{
        router.push('/')
    }
</script>

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值