0

0

如何实现支持自动滚动与手动双向滚动的横幅动画

心靈之曲

心靈之曲

发布时间:2026-03-10 15:13:04

|

868人浏览过

|

来源于php中文网

原创

如何实现支持自动滚动与手动双向滚动的横幅动画

本文介绍在 React 项目中构建一个水平滚动横幅的完整方案:既通过 CSS @keyframes 实现流畅自动滚动,又支持鼠标滚轮/触摸拖拽的双向手动控制,避免因 transform 动画导致内容不可逆丢失的问题。

本文介绍在 react 项目中构建一个水平滚动横幅的完整方案:既通过 css `@keyframes` 实现流畅自动滚动,又支持鼠标滚轮/触摸拖拽的双向手动控制,避免因 `transform` 动画导致内容不可逆丢失的问题。

要实现「自动滚动 + 手动双向滚动」共存的横幅(marquee),关键在于分离动画控制逻辑与 DOM 滚动状态——不能让 CSS transform: translateX() 动画与 scrollLeft 手动操作相互干扰。原问题中手动滚动仅向右生效、左侧内容无法回显,正是因为 translateX(-100%) 将元素整体位移后,scrollLeft 作用于已偏移的视觉容器,造成坐标系错位。

✅ 正确解法是:统一使用 scrollLeft 驱动滚动,将自动滚动也交由 JavaScript 控制(配合 requestAnimationFrame),从而与手动滚轮事件共享同一状态源,确保双向可逆、无缝衔接。

实现手机触屏滑动切换图片特效代码
实现手机触屏滑动切换图片特效代码

基于swiper.js实现手机触屏滑动切换图片特效代码,也支持PC端鼠标滚动自动切换图片特效,支持向上或者向下画的图片,效果还是不错的,非常的流畅,如果再加上向下的箭头会更加的人性化,当前HTML5场景应用非常的流行,大家可以研究下看看。

下载

✅ 推荐实现:纯 scrollLeft 驱动 + 状态同步

以下是一个生产就绪的 React Hook 方案,支持:

  • 鼠标悬停暂停自动滚动
  • 滚轮/触摸拖拽自由左右滚动
  • 自动恢复滚动(离开区域后)
  • 无内存泄漏(正确清理定时器与事件监听)
import { useRef, useState, useEffect, useLayoutEffect } from 'react';

const HorizontalMarquee = ({ children }: { children: React.ReactNode }) => {
  const containerRef = useRef<HTMLDivElement>(null);
  const [isPaused, setIsPaused] = useState(false);
  const [scrollPos, setScrollPos] = useState(0);
  const animationRef = useRef<number>(0);
  const scrollSpeed = 0.5; // px/frame,可调

  // 启动自动滚动动画循环
  const startAutoScroll = () => {
    if (!containerRef.current) return;

    const container = containerRef.current;
    const { scrollWidth, clientWidth } = container;

    const animate = () => {
      if (isPaused || scrollWidth <= clientWidth) return;

      setScrollPos(prev => {
        let next = prev + scrollSpeed;
        // 循环滚动:到达末尾时跳回起点(可选)
        if (next >= scrollWidth - clientWidth) {
          next = 0;
        }
        container.scrollLeft = next;
        return next;
      });

      animationRef.current = requestAnimationFrame(animate);
    };

    animationRef.current = requestAnimationFrame(animate);
  };

  // 清理动画
  useEffect(() => {
    return () => cancelAnimationFrame(animationRef.current);
  }, []);

  // 悬停控制
  const handleMouseEnter = () => setIsPaused(true);
  const handleMouseLeave = () => setIsPaused(false);

  // 手动滚动(兼容滚轮 & 触摸)
  const handleWheel = (e: WheelEvent) => {
    e.preventDefault();
    if (!containerRef.current) return;
    const { scrollLeft } = containerRef.current;
    containerRef.current.scrollLeft = scrollLeft + e.deltaY;
  };

  // 初始化 & 响应 isPaused 变化
  useLayoutEffect(() => {
    if (!isPaused) {
      startAutoScroll();
    } else {
      cancelAnimationFrame(animationRef.current);
    }
  }, [isPaused]);

  return (
    <div
      ref={containerRef}
      className="marquee-container"
      onMouseEnter={handleMouseEnter}
      onMouseLeave={handleMouseLeave}
      onWheel={handleWheel}
      style={{ overflowX: 'auto', scrollBehavior: 'smooth' }}
    >
      <div className="marquee-content">
        {children}
      </div>
    </div>
  );
};

export default HorizontalMarquee;

? 对应 CSS(精简可靠)

.marquee-container {
  display: flex;
  overflow-x: auto;
  scroll-behavior: smooth;
  /* 隐藏滚动条(可选) */
  scrollbar-width: none; /* Firefox */
}
.marquee-container::-webkit-scrollbar {
  display: none; /* Chrome/Safari */
}

.marquee-content {
  display: flex;
  gap: 1rem;
  padding: 0 1rem;
}

⚠️ 注意事项与最佳实践

  • 避免混合 transform 与 scrollLeft:CSS 动画位移会破坏原生滚动上下文,导致 scrollLeft 失效或行为异常。始终选择其一作为唯一滚动源。
  • 使用 useLayoutEffect 启停动画:确保 DOM 更新后立即响应,避免视觉跳变。
  • scroll-behavior: smooth 提升体验:但注意它可能与高频 scrollLeft 更新冲突;若出现卡顿,可改用 scrollTo({ left: pos, behavior: 'auto' }) 或移除此样式。
  • 循环滚动增强:如需无缝循环,可在 scrollWidth - clientWidth 处重置 scrollLeft 为 0(示例中已预留逻辑),或采用双倍内容拼接(适用于静态内容)。
  • 移动端适配:添加 touchstart/touchmove 事件监听,结合 preventDefault() 实现触摸拖拽(本例未展开,但原理一致)。

该方案兼顾性能、可维护性与用户体验,彻底规避了 transform 与 scrollLeft 混用引发的状态不一致问题,是现代 React 项目中实现专业级横幅滚动的推荐路径。

相关标签:

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
DOM是什么意思
DOM是什么意思

dom的英文全称是documentobjectmodel,表示文件对象模型,是w3c组织推荐的处理可扩展置标语言的标准编程接口;dom是html文档的内存中对象表示,它提供了使用javascript与网页交互的方式。想了解更多的相关内容,可以阅读本专题下面的文章。

4286

2024.08.14

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

24

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

80

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

187

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

339

2026.03.04

AI安装教程大全
AI安装教程大全

2026最全AI工具安装教程专题:包含各版本AI绘图、AI视频、智能办公软件的本地化部署手册。全篇零基础友好,附带最新模型下载地址、一键安装脚本及常见报错修复方案。每日更新,收藏这一篇就够了,让AI安装不再报错!

116

2026.03.04

Swift iOS架构设计与MVVM模式实战
Swift iOS架构设计与MVVM模式实战

本专题聚焦 Swift 在 iOS 应用架构设计中的实践,系统讲解 MVVM 模式的核心思想、数据绑定机制、模块拆分策略以及组件化开发方法。内容涵盖网络层封装、状态管理、依赖注入与性能优化技巧。通过完整项目案例,帮助开发者构建结构清晰、可维护性强的 iOS 应用架构体系。

180

2026.03.03

C++高性能网络编程与Reactor模型实践
C++高性能网络编程与Reactor模型实践

本专题围绕 C++ 在高性能网络服务开发中的应用展开,深入讲解 Socket 编程、多路复用机制、Reactor 模型设计原理以及线程池协作策略。内容涵盖 epoll 实现机制、内存管理优化、连接管理策略与高并发场景下的性能调优方法。通过构建高并发网络服务器实战案例,帮助开发者掌握 C++ 在底层系统与网络通信领域的核心技术。

31

2026.03.03

Golang 测试体系与代码质量保障:工程级可靠性建设
Golang 测试体系与代码质量保障:工程级可靠性建设

Go语言测试体系与代码质量保障聚焦于构建工程级可靠性系统。本专题深入解析Go的测试工具链(如go test)、单元测试、集成测试及端到端测试实践,结合代码覆盖率分析、静态代码扫描(如go vet)和动态分析工具,建立全链路质量监控机制。通过自动化测试框架、持续集成(CI)流水线配置及代码审查规范,实现测试用例管理、缺陷追踪与质量门禁控制,确保代码健壮性与可维护性,为高可靠性工程系统提供质量保障。

81

2026.02.28

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号