vue3监听横向滚动条的位置;鼠标滚轮滑动控制滚动条滚动;监听滚动条到顶端

1.横向取值scrollLeft 竖向取值scrollTop

2.可以监听到最左最右侧

3.鼠标滚轮滑动控制滚动条滚动

效果

javascript 复制代码
<template>
  <div>
    <div class="scrollable" ref="scrollableRef">
      <!-- 内容 -->
      <div style="width: 2000px; height: 100px;">横向滚动内容</div>
    </div>
    <p>横向滚动位置: {{ scrollPosition }}</p>
    <p v-if="isAtLeft">已滚动到最左侧</p>
    <p v-if="isAtRight">已滚动到最右侧</p>
  </div>
</template>

<script setup>
import { ref, onMounted, onBeforeUnmount } from 'vue';

const scrollPosition = ref(0);
const isAtLeft = ref(false);
const isAtRight = ref(false);
const scrollableRef = ref(null);

// 处理滚动事件
const handleScroll = () => {
  if (scrollableRef.value) {
    scrollPosition.value = scrollableRef.value.scrollLeft; // 获取横向滚动位置

    // 判断是否滚动到最左侧
    isAtLeft.value = scrollableRef.value.scrollLeft === 0;

    // 判断是否滚动到最右侧
    isAtRight.value = scrollableRef.value.scrollLeft + scrollableRef.value.clientWidth >= scrollableRef.value.scrollWidth;
  }
};

// 处理鼠标滚轮事件
const handleWheel = (event) => {
  if (scrollableRef.value) {
    event.preventDefault(); // 防止默认的垂直滚动
    // 根据鼠标滚轮的方向调整 scrollLeft
    scrollableRef.value.scrollLeft += event.deltaY; // deltaY 表示垂直滚动的距离
    handleScroll(); // 更新滚动位置
  }
};

// 添加和移除事件监听器
onMounted(() => {
  if (scrollableRef.value) {
    scrollableRef.value.addEventListener('scroll', handleScroll);
    scrollableRef.value.addEventListener('wheel', handleWheel); // 添加鼠标滚轮事件监听
  }
});

onBeforeUnmount(() => {
  if (scrollableRef.value) {
    scrollableRef.value.removeEventListener('scroll', handleScroll);
    scrollableRef.value.removeEventListener('wheel', handleWheel); // 移除鼠标滚轮事件监听
  }
});
</script>

<style>
.scrollable {
  width: 300px; /* 设置宽度以启用横向滚动 */
  overflow-x: auto; /* 启用水平滚动 */
  border: 1px solid #ccc;
}
</style>
相关推荐
子兮曰6 小时前
async/await高级模式:async迭代器、错误边界与并发控制
前端·javascript·github
恋猫de小郭7 小时前
2026 Flutter VS React Native ,同时在 AI 时代 VS Native 开发,你没见过的版本
android·前端·flutter
GIS之路9 小时前
ArcGIS Pro 中的 Notebooks 入门
前端
IT_陈寒10 小时前
React状态管理终极对决:Redux vs Context API谁更胜一筹?
前端·人工智能·后端
lemon_yyds11 小时前
《vue 2 升级vue3 父组件 子组件 传值: value 和 v-model
vue.js
Kagol11 小时前
TinyVue 支持 Skills 啦!现在你可以让 AI 使用 TinyVue 组件搭建项目
前端·agent·ai编程
柳杉11 小时前
从零打造 AI 全球趋势监测大屏
前端·javascript·aigc
simple_lau11 小时前
Cursor配置MasterGo MCP:一键读取设计稿生成高还原度前端代码
前端·javascript·vue.js
睡不着先生11 小时前
如何设计一个真正可扩展的表单生成器?
前端·javascript·vue.js
天蓝色的鱼鱼11 小时前
模块化与组件化:90%的前端开发者都没搞懂的本质区别
前端·架构·代码规范