前端:横向滚动条,拖动进行左右滚动(含隐藏滚动条)

效果:

代码:

单独封装一个addMouseEvent.ts文件

TypeScript 复制代码
// 添加鼠标移动事件

export const addMouseEvent = (el: string) => {
	let container = document.querySelector(el) as HTMLDivElement;
	let isMouseDown = false;
	let startX = 0;
	let scrollLeft = 0;

	// 鼠标按下事件
	const onMouseDown = (e: MouseEvent) => {
		isMouseDown = true;
		startX = e.pageX - container.offsetLeft;
		scrollLeft = container.scrollLeft;
	};
	// 鼠标移动事件
	const onMouseMove = (e: MouseEvent) => {
		if (!isMouseDown) return;
		e.preventDefault();
		let x = e.pageX - container.offsetLeft;
		let walk = (x - startX) * 1; // 调整滚动速度
		container.scrollLeft = scrollLeft - walk;
	};
	// 鼠标抬起事件
	const onMouseUp = () => {
		isMouseDown = false;
	};
	// 鼠标离开事件
	const onMouseLeave = () => {
		isMouseDown = false;
	};

	container.addEventListener("mousedown", function (e) {
		onMouseDown(e);
	});
	container.addEventListener("mouseleave", function () {
		onMouseLeave();
	});
	container.addEventListener("mouseup", function () {
		onMouseUp();
	});
	container.addEventListener("mousemove", function (e) {
		onMouseMove(e);
	});

	const removeEventListeners = () => {
		container.removeEventListener("mousedown", onMouseDown);
		container.removeEventListener("mouseleave", onMouseLeave);
		container.removeEventListener("mouseup", onMouseUp);
		container.removeEventListener("mousemove", onMouseMove);
	};
	return removeEventListeners;
};

在页面中使用:

.device-list是要执行滑动的dom元素

TypeScript 复制代码
onMounted(() => {
	nextTick(() => {
		mouseLeaveEvent.value = addMouseEvent(".device-list");
	});
});
onBeforeUnmount(() => {
	mouseLeaveEvent.value && mouseLeaveEvent.value();
});

隐藏横向滚动条:

css 复制代码
::-webkit-scrollbar {
	/* 隐藏Webkit浏览器的滚动条 */
	display: none;
}
相关推荐
烬羽4 小时前
后端返回的 JSON 字符串,浏览器怎么"看懂"的?——Ajax 全链路拆解
javascript
tedcloud1234 小时前
taste-skill部署教程:打造个性化AI推荐工作流
服务器·前端·人工智能·系统架构·edge
赴生-4 小时前
C++进阶 异常
开发语言·c++
xinhuanjieyi4 小时前
html修复游戏种太阳错误
前端·游戏·html
黄毛火烧雪下4 小时前
Java 核心知识点总结(一)
java·开发语言
半个落月5 小时前
一个新手用 Bun + Axios 调通 DeepSeek API 的实践记录
javascript
其实防守也摸鱼5 小时前
软件安全与漏洞--软件安全编码与防御技术理论题库
开发语言·网络·安全·网络安全·软件安全·软件安全与漏洞
不好听6135 小时前
深入理解链表:线性数据结构的另一面
javascript·数据结构
x138702859575 小时前
c语言中srtlen(指针使用计算字符长度)、传值和传址调用
c语言·开发语言·算法·visual studio
林希_Rachel_傻希希5 小时前
学React治好了我的焦虑症,1小时速通React 前20分钟。
前端·javascript·面试