通过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)
                    }
                },
相关推荐
xiaoqi92241 分钟前
React Native鸿蒙跨平台如何进行狗狗领养中心,实现基于唯一标识的事件透传方式是移动端列表开发的通用规范
javascript·react native·react.js·ecmascript·harmonyos
jin1233221 小时前
React Native鸿蒙跨平台剧本杀组队消息与快捷入口组件,包含消息列表展示、快捷入口管理、快捷操作触发和消息详情预览四大核心功能
javascript·react native·react.js·ecmascript·harmonyos
烬头88213 小时前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas1363 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
2601_949833393 小时前
flutter_for_openharmony口腔护理app实战+预约管理实现
android·javascript·flutter
军军君014 小时前
Three.js基础功能学习十三:太阳系实例上
前端·javascript·vue.js·学习·3d·前端框架·three
xiaoqi9225 小时前
React Native鸿蒙跨平台如何实现分类页面组件通过searchQuery状态变量管理搜索输入,实现了分类的实时过滤功能
javascript·react native·react.js·ecmascript·harmonyos
qq_177767375 小时前
React Native鸿蒙跨平台实现应用介绍页,实现了应用信息卡片展示、特色功能网格布局、权限/联系信息陈列、评分展示、模态框详情交互等通用场景
javascript·react native·react.js·ecmascript·交互·harmonyos
2603_949462105 小时前
Flutter for OpenHarmony社团管理App实战:预算管理实现
android·javascript·flutter
wuhen_n6 小时前
JavaScript内存管理与执行上下文
前端·javascript