0

0

JavaScript/jQuery实现循环自动滚动与鼠标悬停暂停教程

花韻仙語

花韻仙語

发布时间:2025-11-20 14:14:34

|

267人浏览过

|

来源于php中文网

原创

JavaScript/jQuery实现循环自动滚动与鼠标悬停暂停教程

本教程详细阐述如何利用javascriptjqueryhtml元素创建平滑的循环自动滚动功能,使其内容在上下方向持续滚动。同时,文章还将指导您如何集成鼠标悬停暂停效果,提升用户体验,确保在用户需要阅读特定内容时,滚动行为能够及时停止。

一、引言

网页设计中,有时我们需要在有限的区域内展示大量内容,例如新闻列表、公告板或产品特色。为了优化空间利用和内容展示,实现一个自动滚动且能循环往复的组件变得尤为实用。更进一步,为了提供良好的用户体验,我们还需要在用户对滚动内容感兴趣时,提供暂停功能。本教程将指导您如何使用jQuery实现一个具备循环上下滚动和鼠标悬停暂停功能的HTML内容区域。

二、核心技术概览

实现此功能主要依赖以下前端技术:

  • jQuery库: 简化DOM操作、事件处理和动画效果。
  • scrollTop属性: 控制或获取元素垂直滚动条的位置。
  • scrollHeight属性: 获取元素内容的总高度(包括被隐藏的部分)。
  • animate()方法: jQuery提供的强大动画方法,用于平滑地改变CSS属性,如scrollTop。
  • mouseenter和mouseleave事件: 用于检测鼠标进入和离开元素区域,实现暂停和恢复功能。

三、HTML结构准备

首先,我们需要一个包含可滚动内容的HTML div 元素。这个 div 将作为我们自动滚动的目标容器。

<div id="div1">
  <!-- 放置大量内容,确保其高度超过容器高度以触发滚动条 -->
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
  This is a DIV<br>
</div>
<!-- 引入jQuery库,通常放在</body>标签前 -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

四、CSS样式定义

为确保 div 元素具有固定的高度和宽度,并且在内容溢出时显示滚动条,我们需要定义相应的CSS样式。

立即学习Java免费学习笔记(深入)”;

#div1 {
  height: 100px; /* 固定高度 */
  width: 200px;  /* 固定宽度 */
  border: 1px solid #ccc; /* 边框 */
  overflow: auto; /* 内容溢出时显示滚动条 */
}

五、JavaScript逻辑实现

核心的滚动和暂停逻辑将通过JavaScript(结合jQuery)实现。

Glimmer Ai
Glimmer Ai

基于GPT-3和DALL·E2的PPT制作工具

下载

1. 状态变量定义

为了控制滚动的行为和状态,我们需要定义几个关键变量:

var scrollSpeed = 5000;    // 滚动动画完成一次所需时间(毫秒)
var scrollDirection = 1;   // 滚动方向:1为向下,-1为向上
var paused = false;        // 全局暂停标志
var isMouseOver = false;   // 鼠标是否悬停在元素上

2. startScroll() 函数

这个函数是实现自动滚动循环的核心。它负责根据当前滚动方向启动动画,并在动画完成后切换方向并重新调用自身,形成循环。

function startScroll() {
  var div1 = $('#div1');
  var divHeight = div1.height();           // 容器可见高度
  var scrollHeight = div1.prop('scrollHeight'); // 内容总高度

  // 如果内容高度不大于容器高度,则无需滚动
  if (scrollHeight <= divHeight) {
    return;
  }

  // 只有在未暂停且鼠标未悬停时才执行滚动
  if (!paused && !isMouseOver) {
    if (scrollDirection === 1) { // 当前方向为向下
      // 向下滚动到最底部 (scrollHeight - divHeight 是实际可滚动到的最大值)
      div1.animate({ scrollTop: scrollHeight - divHeight }, scrollSpeed, 'linear', function() {
        scrollDirection = -1; // 滚动到底部后,将方向改为向上
        startScroll();        // 再次调用,启动向上滚动
      });
    } else { // 当前方向为向上
      // 向上滚动到最顶部
      div1.animate({ scrollTop: 0 }, scrollSpeed, 'linear', function() {
        scrollDirection = 1;  // 滚动到顶部后,将方向改为向下
        startScroll();        // 再次调用,启动向下滚动
      });
    }
  }
}

说明: 在 animate 方法中,第三个参数 'linear' 指定了动画的缓动效果,使其滚动速度

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

156

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

335

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

406

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

515

2023.12.04

jquery实现分页方法
jquery实现分页方法

在jQuery中实现分页可以使用插件或者自定义实现。想了解更多jquery分页的相关内容,可以阅读本专题下面的文章。

312

2023.12.06

jquery中隐藏元素是什么
jquery中隐藏元素是什么

jquery中隐藏元素是非常重要的一个概念,在使用jquery隐藏元素之前,需要先了解css样式中关于元素隐藏的属性,比如display、visibility、opacity等属性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

128

2024.02.23

jquery中什么是高亮显示
jquery中什么是高亮显示

jquery中高亮显示是指对页面搜索关键词时进行高亮显示,其实现办法:1、先获取要高亮显示的行,获取搜索的内容,再遍历整行内容,最后添加高亮颜色;2、使用“jquery highlight”高亮插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

183

2024.02.23

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

51

2026.01.13

C# ASP.NET Core微服务架构与API网关实践
C# ASP.NET Core微服务架构与API网关实践

本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

76

2026.03.11

热门下载

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

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.9万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.6万人学习

CSS教程
CSS教程

共754课时 | 42.6万人学习

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

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