点击按钮滚动到底功能vue的v-on:scroll运用

使用vue自带的监听滚动功能v-on:scroll,滚动条变化时,会调用方法 checkScrollStatus,如果滚动条在容器底部时,则隐藏按钮,否则显示按钮,点击按钮能一键滚动到底部。

html 复制代码
<div class="chat-area" ref="chatAreaRef" v-on:scroll="checkScrollStatus">
   ...具体渲染的内容
</div>

<-- 按钮 -->
<div @click="scrollBottom" class="scroll-btn" v-show="showScrollBtn">
    <i class="iconfont icon-a-zhedieiconbeifen5" />
</div>

    // 样式 这里因为内容区域是对话框,所以反转了dom
    .chat-area {
      height: 0;
      flex: 1;
      overflow-y: auto;
      display: flex;
      flex-direction: column-reverse;
    }

这里因为内容区域是对话框,所以反转了dom,所以下面的方法里的container.scrollTop在滚动到底的时候是0,正常的dom不是0

javascript 复制代码
      const chatAreaRef = ref(null)

      // 检查滚动状态并更新按钮显示
      checkScrollStatus() {
        
        // 确保DOM已加载
        if (!chatAreaRef.value) return;
        
        const container = chatAreaRef.value;
        const scrollPosition = container.scrollTop;
        // console.log('元素内部滚动距离:', scrollPosition);

        // 内容高度 > 容器高度(存在滚动条)
        const hasScrollbar = container.scrollHeight > container.clientHeight;

        // 1. 内容高度 > 容器高度(存在滚动条)
        if (hasScrollbar) {
          // 底部对应 scrollPosition = 0 → 隐藏按钮
          // 非底部对应 scrollPosition ≠ 0 → 显示按钮
          if (scrollPosition !== 0) {
            state.showScrollBtn = true
          } else {
            state.showScrollBtn = false
          }
        } else {
          state.showScrollBtn = false
        }
        // console.log(state.showScrollBtn, '--showScrollBtn--')
      },
      // 滚动到底部
      scrollBottom() {
        if (!chatAreaRef.value) return;
        const container = chatAreaRef.value;
          chatAreaRef.value.scrollTo({
            top: 0,
            behavior: 'smooth'
          });
          
        // 滚动后更新按钮状态
        nextTick(() => {
          methods.checkScrollStatus();
        })
      },
相关推荐
两个西柚呀16 分钟前
未在props中声明的属性
前端·javascript·vue.js
SteveJrong3 小时前
面试题 - JavaScript
前端·javascript·面试·ecmascript·基础·找工作·红宝书
阿金要当大魔王~~3 小时前
uniapp 页面标签 传值 ————— uniapp 定义 接口
前端·javascript·uni-app·1024程序员节
一个处女座的程序猿O(∩_∩)O4 小时前
Vue-Loader 深度解析:原理、使用与最佳实践
前端·javascript·vue.js
还是大剑师兰特5 小时前
TypeScript 面试题及详细答案 100题 (91-100)-- 工程实践与框架集成
前端·javascript·typescript·1024程序员节
可触的未来,发芽的智生5 小时前
触摸未来2025-10-25:蓝图绘制
javascript·python·神经网络·程序人生·自然语言处理
用户47949283569155 小时前
typeof null === 'object':JavaScript 最古老的 bug 为何 30 年无法修复?
前端·javascript·面试
非凡ghost5 小时前
By Click Downloader(下载各种在线视频) 多语便携版
前端·javascript·后端
非凡ghost6 小时前
VisualBoyAdvance-M(GBA模拟器) 中文绿色版
前端·javascript·后端
非凡ghost6 小时前
K-Lite Mega/FULL Codec Pack(视频解码器)
前端·javascript·后端