通过css3的锚定滚动属性,实现分页加载时让滚动条不闪动

html标签

html 复制代码
<div  @scroll="handleScroll" id="list-container"
     style="overflow-anchor:auto;overflow-y: auto;height: 80vh">
    <ul id="talks"
        v-for="(item,index) in msgList"
        :key="item.roleid+item.time+item.content">
        <li >
            <div>
                <span class="message-data-time"> {{item.rolename}}{{item.roleid}}{{ '&nbsp;&nbsp;' }}{{ item.time | formatTime }}</span>
            </div>
            <div>
                <span>{{item.content}}</span>
            </div>
        </li>
    </ul>
</div>

Vue生命周期中的mounted挂载,监听滚动事件

js 复制代码
mounted() {
    // 给div标签添加监听滚动事件
    window.addEventListener('scroll', this.handleScroll);
    const listContainer = document.getElementById('list-container');
    listContainer.scrollTo(0, 1)
},

步骤

使用的是vue2框架

  1. 在v-for中,需要给遍历的列表的:key绑定跟列表存储数据相关的唯一值,注意不能使用index进行绑定,否则当列表最前面有新数组拼接在前面时,vue会直接替换列表中的元素,并且认为列表绑定的元素位置一直没有变动。因此需要绑定列表中元素特有的唯一值为key,最好key不要有重复或者中文,否则会报错,如案例中的:key="item.roleid+item.time+item.content"

  2. 同时给div标签添加固定高度以出现滚动条,如案例中的80vh

  3. 添加stytle,style="overflow-anchor:auto;overflow-y: auto;height: 80vh"

  4. 注意,如果在首次进入页面时,vue会认为我们并没有进行滚动,因此不会绑定唯一值,此时我们可以手动设置scrollTop为1,让vue的v-for绑定列表元素,如案例中mounted(),页面一挂载就让div的滚动条滚动到位置1,同时如果当滚动条处于位置0时,我们需要手动把滚动条位置设置为1,这样才能触发锚定滚动,eg:

    html 复制代码
                handleScroll(e) {
                    // 滚动位置
                    const scrollTop = e.srcElement.scrollTop;
                    // 判断是否滚动到页面顶部
                    if (scrollTop === 0) {
                        const listContainer = document.getElementById('list-container');
                        listContainer.scrollTo(0, 1)
                    }
                },
相关推荐
计算机学姐3 小时前
基于SpringBoot的社团管理系统【2026最新】
java·vue.js·spring boot·后端·mysql·spring·mybatis
烛阴3 小时前
解锁 TypeScript 的元编程魔法:从 `extends` 到 `infer` 的条件类型之旅
前端·javascript·typescript
前端开发爱好者4 小时前
弃用 ESLint + Prettier!快 35 倍的 AI 格式化神器!
前端·javascript·vue.js
wayhome在哪4 小时前
Cropper.js 轻松拿捏前端裁剪🤞
javascript·canvas·设计
&白帝&4 小时前
vue2和vue3的对比
javascript·vue.js·ecmascript
江东大都督周总4 小时前
rabbitmq集群
javascript·rabbitmq·ruby
一嘴一个橘子4 小时前
uniapp 顶部tab + 占满剩余高度的内容区域swiper
javascript·uni-app
wayhome在哪5 小时前
30KB 轻量王者!SortableJS 轻松搞定拖拽需求
javascript·设计·dom
骑驴看星星a5 小时前
Vue中的scoped属性
前端·javascript·vue.js
四月_h5 小时前
在 Vue 3 + TypeScript 项目中实现主题切换功能
前端·vue.js·typescript