vue2 div滚动条下拉到底部时触发事件(懒加载) 超级简易版本的懒加载

简介: 【6月更文挑战第4天】导文vue2 div滚动条下拉到底部时触发事件(懒加载) 超级简易版本的懒加载文章重点内容效果展示:当div拉到底部的时候:在这里插入图片描述编辑器返回:在这里插入图片描述代码展示在Vue 2中,可以通过监听div的scroll事件来判断滚动条是否到达了底部。以下是一个简单的示例:

导文

vue2 div滚动条下拉到底部时触发事件(懒加载) 超级简易版本的懒加载

文章重点

内容效果展示:

当div拉到底部的时候:

编辑器返回:

代码展示

在Vue 2中,可以通过监听div的scroll事件来判断滚动条是否到达了底部。以下是一个简单的示例:

<template>
  <div class="scroll-container" @scroll="handleScroll">
    <!-- 内容 -->
    <div v-for="item in items" :key="item">{{ item }}</div>
    <!-- 内容 -->
  </div>
</template>
 
<script>
export default {
  data() {
    return {
      items: [...Array(100).keys()].map(i => `Item ${i + 1}`), // 示例数据
    };
  },
  methods: {
    handleScroll(event) {
      const { scrollTop, clientHeight, scrollHeight } = event.target;
      if (scrollTop + clientHeight >= scrollHeight) {
        // 滚动条到达底部,触发懒加载
        this.loadMore();
      }
    },
    loadMore() {
      // 这里添加加载更多数据的逻辑
      console.log('到达底部,触发懒加载');
      // 例如,可以添加更多数据到items数组中
      // this.items.push(...newItems);
    }
  }
};
</script>
 
<style>
.scroll-container {
  height: 300px; /* 设置一个固定的高度 */
  overflow-y: auto; /* 开启滚动 */
}
</style>

在这个示例中,.scroll-container 是一个具有固定高度并且内容可滚动的div。我们通过监听scroll事件来获取滚动容器的scrollTop(滚动条的垂直位置)、clientHeight(可视区域的高度)和scrollHeight(整个内容的高度)。当scrollTop + clientHeight的值大于或等于scrollHeight时,说明滚动条已经到达了底部,我们可以在这时候触发loadMore方法来加载更多数据。

这些方法适用于哪些场景

在Vue 2中,通过监听div滚动事件来实现懒加载的方法适用于以下场景:

无限滚动/滚动加载更多:这是最常见的使用场景。当用户滚动到页面底部或某个容器底部时,自动加载更多内容,通常用于新闻流、社交媒体帖子、图片墙等。

聊天应用:在聊天应用中,当用户滚动到聊天历史记录的底部时,可以自动加载更早的消息或新消息。

图片/视频懒加载:对于大量图片或视频的页面,懒加载可以显著提高性能。只有当用户滚动到图片或视频所在的位置时,才开始加载它们。

虚拟滚动:对于处理大量数据的情况,虚拟滚动是一种高效的解决方案。它仅渲染视口内的数据项,并在用户滚动时动态更新。当用户滚动到底部时,可以触发事件来加载新数据或更新渲染。

分页替代方案:在某些情况下,你可能不想使用传统的分页方式,而希望在用户滚动到底部时加载下一页内容。

动态内容生成:根据用户滚动位置动态生成内容,比如地图上的标记点、动态图表等。

广告加载:在广告展示中,当用户滚动到页面底部时,可以触发广告内容的加载。

自定义滚动行为:任何需要自定义滚动行为的场景,比如特殊的滚动效果、滚动动画等。

需要注意的是,这种方法对于性能有一定要求,因为滚动事件可能会频繁触发。因此,在实现时应该采取防抖(debounce)或节流(throttle)技术来限制处理函数的执行频率,以提高性能。对于移动设备上的滚动性能,还需要特别关注触摸事件的处理和滚动优化。在Vue中,可以使用第三方库如vue-scroll或vue-infinite-scroll来更方便地实现滚动加载功能。

总结

通过监听div的scroll事件,可以获取滚动容器的相关属性,如滚动条的位置、可视区域的高度以及整个内容的高度。当滚动条到达底部时,可以执行相应的懒加载逻辑,比如加载更多数据。

您好,我是肥晨。

欢迎关注我获取前端学习资源,日常分享技术变革,生存法则;行业内幕,洞察先机。

目录
相关文章
|
4月前
Vue3随内容增加滚动到底部
Vue3随内容增加滚动到底部
160 0
|
4月前
|
测试技术
【sgLazyCascader】自定义组件:基于el-cascader的懒加载级联菜单,支持异步加载子级菜单
【sgLazyCascader】自定义组件:基于el-cascader的懒加载级联菜单,支持异步加载子级菜单
uniapp动态禁用mescroll-body组件的下拉刷新,或者动态禁用mescroll-body组件的上拉加载
uniapp动态禁用mescroll-body组件的下拉刷新,或者动态禁用mescroll-body组件的上拉加载
343 0
|
2月前
|
JavaScript
【vue】 vue2 监听滚动条滚动事件
【vue】 vue2 监听滚动条滚动事件
97 1
|
2月前
|
JavaScript
vue 组件封装 | s-fullpage 全屏滚动 (内含绑定鼠标滑轮滚动事件、避免鼠标滑轮连续滚动、滑动过渡动画等实用技巧)
vue 组件封装 | s-fullpage 全屏滚动 (内含绑定鼠标滑轮滚动事件、避免鼠标滑轮连续滚动、滑动过渡动画等实用技巧)
47 4
|
3月前
|
JavaScript
vue滚动到页面底部时加载
vue滚动到页面底部时加载
26 1
|
2月前
|
JavaScript
vue 组件封装 | s-scroll 页面滚动动画
vue 组件封装 | s-scroll 页面滚动动画
25 0
|
2月前
|
JavaScript
vue【解决方案】页面/路由跳转后,滚动条消失,页面无法滚动
vue【解决方案】页面/路由跳转后,滚动条消失,页面无法滚动
137 0
|
4月前
|
自然语言处理 JavaScript 前端开发
vue2 div滚动条下拉到底部时触发事件(懒加载) 超级简易版本的懒加载
vue2 div滚动条下拉到底部时触发事件(懒加载) 超级简易版本的懒加载
205 2
|
缓存
uniapp的mescroll-body组件与页面切换冲突.mescroll-body组件下拉异常,mescroll-body组件页面跳转回来后下滑屏幕直接触发了下拉刷新.
uniapp的mescroll-body组件与页面切换冲突.mescroll-body组件下拉异常,mescroll-body组件页面跳转回来后下滑屏幕直接触发了下拉刷新.
259 0