<template>
<div class="scroll-container" ref="scrollContainer"
v-on:mousedown="handleMouseDown"
v-on:mousemove="handleMouseMove"
v-on:mouseup="handleMouseUp">
<div class="scroll-content">
<!-- 横向内容 -->
</div>
</div>
</template>
<style>
.scroll-container {
overflow-x: scroll;
white-space: nowrap;
}
.scroll-content {
/* 横向内容样式 */
}
</style>
<script setup lang="ts">
import { ref } from 'vue'
let isDragging = false
let startX = 0
let scrollLeft = 0
const scrollContainer = ref(null)
function handleMouseDown(event: MouseEvent) {
isDragging = true;
startX = event.clientX;
scrollLeft = scrollContainer.value.scrollLeft;
}
function handleMouseMove(event: MouseEvent) {
if (!isDragging) return;
const x = event.clientX - startX;
scrollContainer.value.scrollLeft = scrollLeft - x;
}
function handleMouseUp() {
isDragging = false;
}
</script>
标签:function,startX,Vue,拖动,scrollLeft,滚动条,isDragging,scrollContainer,event
From: https://www.cnblogs.com/pphboy/p/17441726.html