新闻中心
使用 jQuery 和 CSS 实现流畅的鼠标滚轮控制水平滚动效果

本教程详细阐述如何利用 jquery 和 css 创建一个响应鼠标滚轮事件的水平滚动页面。我们将通过 css 的 `display: inline-block` 和 `white-space: nowrap` 构建横向布局,并结合 jquery 监听 `wheel` 事件,通过 css `transform: translatex` 实现平滑的滚动动画。文章还将重点介绍如何计算并实现滚动边界检测,确保用户无法过度滚动,从而提供流畅且受控的用户体验。
在现代网页设计中,水平滚动效果为用户提供了独特的浏览体验,尤其适用于展示一系列内容或产品。通过巧妙结合 CSS 布局与 jQuery 的事件处理能力,我们可以实现一个由鼠标滚轮驱动的平滑水平滚动页面,并加入必要的边界检测以优化用户体验。
1. HTML 结构:构建可滚动的区块
首先,我们需要一个清晰的 HTML 结构来承载水平滚动的各个内容区域。通常,我们会使用一个容器元素包裹多个“section”或“slide”元素。
<!DOCTYPE html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>水平滚动教程</title>
<link rel="stylesheet" href="style.css">
<!-- 引入 jQuery 库 -->
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>
</head>
<body>
<div class="scroll-sections">
<section id="section-1">
<div class="container">
<div class="row">
<div class="col-md-12">
<h1>第一部分</h1>
<p>这是第一部分的内容。</p>
</div>
</div>
</div>
</section>
<section id="section-2">
<div class="container">
<div class="row">
<div class="col-md-12">
<h1>第二部分</h1>
<p>这是第二部分的内容。</p>
</div>
</div>
</div>
</section>
<section id="section-3">
<div class="container">
<div class="row">
<div class="col-md-12">
<h1>第三部分</h1>
<p>这是第三部分的内容。</p>
</div>
</div>
</div>
</section>
<section id="section-4">
<div class="container">
<div class="row">
<div class="col-md-12">
<h1>第四部分</h1>
<p>这是第四部分的内容。</p>
</div>
</div>
</div>
</section>
<section id="section-5">
<div class="container">
<div class="row">
<div class="col-md-12">
<h1>第五部分</h1>
<p>这是第五部分的内容。</p>
<div class="aritcle_card">
<a class="aritcle_card_img" href="/ai/1125">
<img src="https://img.php.cn/upload/ai_manual/000/000/000/175680079579055.png" alt="OneStory">
</a>
<div class="aritcle_card_info">
<a href="/ai/1125">OneStory</a>
<p>OneStory 是一款创新的AI故事生成助手,用AI快速生成连续性、一致性的角色和故事。</p>
<div class="">
<img src="/static/images/card_xiazai.png" alt="OneStory">
<span>319</span>
</div>
</div>
<a href="/ai/1125" class="aritcle_card_btn">
<span>查看详情</span>
<img src="/static/images/cardxiayige-3.png" alt="OneStory">
</a>
</div>
</div>
</div>
</div>
</section>
</div>
<script src="script.js"></script>
</body>
</html>请注意,我们引入了 jQuery 库,并且 scroll-sections 容器内包含多个 section 元素,每个 section 代表一个独立的滚动内容区块。
2. CSS 样式:实现水平布局与平滑过渡
CSS 是实现水平布局和视觉平滑度的关键。我们将利用 display: inline-block 将各个 section 排列在一行,并通过 white-space: nowrap 防止它们换行。同时,为了实现平滑的滚动效果,我们会为 scroll-sections 容器添加 transition-duration 属性。
/* style.css */
html, body {
margin: 0;
overflow: hidden; /* 隐藏默认的垂直滚动条,防止冲突 */
height: 100%;
width: 100%;
}
.scroll-sections {
white-space: nowrap; /* 确保所有子元素都在一行显示 */
height: 100%;
position: relative; /* 为 transform 动画提供定位上下文 */
font-size: 0; /* 消除 inline-block 元素之间的默认间距 */
transition-duration: 0.5s; /* 设置 CSS 动画过渡时间,使滚动更平滑 */
transition-property: transform; /* 只对 transform 属性应用过渡效果 */
}
section {
height: 99vh; /* 确保每个区块占据几乎整个视口高度 */
display: inline-block; /* 使区块水平排列 */
width: 33.333%; /* 示例:每个区块占据视口宽度的三分之一 */
vertical-align: top; /* 垂直对齐 inline-block 元素 */
font-size: 1rem; /* 恢复内容字体大小 */
/* border: 1px solid #ccc; /* 可选:用于可视化区块边界 */
box-sizing: border-box; /* 确保 padding 和 border 不会增加元素总宽度 */
display: flex; /* 使用 flexbox 居中内容 */
justify-content: center;
align-items: center;
}
/* 示例内容样式,可根据需要调整 */
.container {
width: 90%;
margin: 0 auto;
text-align: center;
}
h1 {
font-size: 3em;
color: #333;
}
p {
font-size: 1.2em;
color: #666;
}
/* 为不同 section 添加背景色以便区分 */
#section-1 { background-color: #f0f8ff; }
#section-2 { background-color: #e0ffff; }
#section-3 { background-color: #f5f5dc; }
#section-4 { background-color: #fffacd; }
#section-5 { background-color: #faebd7; }关键点说明:
- html, body { overflow: hidden; }:这非常重要,它禁用了浏览器默认的垂直滚动行为,避免与我们的自定义水平滚动冲突。
- .scroll-sections { white-space: nowrap; font-size: 0; }:white-space: nowrap 强制所有 section 保持在同一行,font-size: 0 则用于消除 inline-block 元素之间因空格或换行符产生的默认间距。
- .scroll-sections { transition-duration: 0.5s; transition-property: transform; }:当 transform 属性发生变化时,CSS 会在 0.5 秒内平滑过渡,从而实现流畅的滚动动画。
- section { width: 33.333%; }:这里设置每个区块占据视口宽度的三分之一。您可以根据设计需求调整此值,例如设置为 100vw 实现全屏滚动。
3. J*aScript 逻辑:鼠标滚轮事件与边界检测
接下来,我们使用 jQuery 来监听鼠标滚轮事件,并根据滚轮方向调整 scroll-sections 容器的 transform: translateX 属性,同时实现关键的边界检测。
// script.js
$(document).ready(function(){
var currentScrollPos = 0; // 当前的滚动位置,初始为0(最左侧)
var $scrollSections = $(".scroll-sections");
var $lastSection = $scrollSections.children().last();
// 计算最大可滚动距离(最右侧边界)
// 逻辑:视口宽度 - 所有 section 的总宽度
// 当 translateX 等于这个值时,表示最右侧的 section 刚好显示在视口最右侧
function calculateMaxScroll() {
var totalSectionsWidth = 0;
$scrollSections.children('section').each(function() {
totalSectionsWidth += $(this).outerWidth(true); // 包含 margin, padding, border
});
return $(window).width() - totalSectionsWidth;
}
var maxScroll = calculateMaxScroll();
// 监听鼠标滚轮事件
// 'wheel' 事件是现代浏览器推荐的事件,兼容性比 'mousewheel' 和 'DOMMouseScroll' 更好
$scrollSections.on('wheel', function(event) {
// event.originalEvent.wheelDelta 适用于 Chrome/Safari
// event.originalEvent.deltaY 适用于 Firefox (负值表示向上滚动,正值表示向下滚动)
// 统一处理滚轮方向:向上滚动(wheelDelta > 0 或 deltaY < 0)向右移动内容
// 向下滚动(wheelDelta < 0 或 deltaY > 0)向左移动内容
var delta = event.originalEvent.wheelDelta || -event.originalEvent.deltaY;
// 根据滚轮方向调整滚动位置
// delta / 3 用于调整滚动速度,可根据需要修改
currentScrollPos += (delta / 3);
// 边界检测:防止过度滚动
if (currentScrollPos > 0) {
currentScrollPos = 0; // 滚动到最左侧边界
}
if (currentScrollPos < maxScroll) {
currentScrollPos = maxScroll; // 滚动到最右侧边界
}
// 应用 CSS transform 实现水平滚动
$scrollSections.css({'transform': 'translateX(' + currentScrollPos + 'px)'});
// 阻止默认的滚动行为(例如页面的垂直滚动)
return false;
});
// 窗口大小调整时重新计算最大滚动距离
$(window).on('resize', function() {
maxScroll = calculateMaxScroll();
// 调整窗口后,如果当前位置超出边界,将其修正到最近的边界
if (currentScrollPos > 0) {
currentScrollPos = 0;
} else if (currentScrollPos < maxScroll) {
currentScrollPos = maxScroll;
}
$scrollSections.css({'transform': 'translateX(' + currentScrollPos + 'px)'});
});
});代码详解:
- currentScrollPos: 这是一个变量,用于存储 scroll-sections 容器当前的 translateX 值。初始值为 0,表示内容位于最左侧。
-
calculateMaxScroll():
- 这个函数用于动态计算最大可向左滚动的距离。
- 它首先遍历所有的 section 元素,累加它们的 outerWidth(true)(包括边距、内边距和边框),得到所有 section 的总宽度。
- 然后,用当前视口宽度减去这个总宽度,得到一个负值。这个负值就是 translateX 可以达到的最小(最左)值。例如,如果视口宽 1000px,内容总宽 2000px,那么 maxScroll 就是 1000 - 2000 = -1000px。当 translateX 为 -1000px 时,内容最右侧刚好对齐视口最右侧。
-
$scrollSections.on('wheel', function(event) { ... });:
- wheel 事件是现代浏览器中用于检测鼠标滚轮活动的标准事件。
- event.originalEvent.wheelDelta (Chrome/Safari) 或 -event.originalEvent.deltaY (Firefox) 用于获取滚轮滚动的方向和强度。
- wheelDelta > 0 或 deltaY
- wheelDelta 0 表示向下滚动。
- currentScrollPos += (delta / 3):根据滚轮方向和强度更新 currentScrollPos。除以 3 是为了调整滚动速度,使其更平滑,避免一次滚动过快。
-
边界检测:
- if (currentScrollPos > 0) { currentScrollPos = 0; }:如果 currentScrollPos 尝试超过 0(即向右滚出起始位置),则将其重置为 0,防止向左过度滚动。
- `if (currentScrollPos
以上就是使用 jQuery 和 CSS 实现流畅的鼠标滚轮控制水平滚动效果的详细内容,更多请关注其它相关文章!
# 第一部分
# seo为什么拍不上去
# 本科景区网站建设论文
# 林东泽seo
# 济南冰河世纪网站建设
# 辣条广告营销推广方案怎么写
# 妇幼医院网站推广公司
# 大余网站搜索引擎优化
# 福州网站seo介绍
# 产品seo推广费用
# 温州seo营销方案
# 都在
# 可根据
# 第四部分
# 如何做
# 第二部分
# css
# 多个
# 适用于
# 这是
# 鼠标
# cd
# win
# ai
# safari
# 浏览器
# ajax
# js
# html
# jquery
# java
# javascript
相关栏目:
【
科技资讯46185 】
【
网络学院92790 】
相关推荐:
Lar*el如何正确地在控制器和模型之间分配逻辑_Lar*el代码职责分离与架构建议
初次安装JDK时环境变量如何正确配置_J*A_HOME与PATH设置规则讲解
深入理解Google Cloud Datastore查询:祖先路径与数据一致性
Selenium Python中处理点击后新窗口加载冻结问题的策略与实践
python3时间如何用calendar输出?
如何在复杂的电商平台中优雅地管理共享资源并确保正确重定向,使用spryker-shop/resource-share-page模块助你一臂之力
b站怎么看视频的弹幕数量_b站弹幕数量查看方法
uc浏览器网页版极速入口 uc网页浏览器网页版流畅体验
必由学网页版入口 必由学官方平台直接访问
Yandex浏览器官方网页版入口 Yandex浏览器最新版官网
单射、满射与双射的关系 一文理清所有逻辑
如何在CSS中使用浮动制作导航栏_float实现水平菜单
Go语言中动态执行代码字符串的策略与实践
夸克AO3官网入口_AO3镜像网站2025推荐
小红书怎么解除第三方平台绑定_小红书多平台登录解绑方法介绍
理解Python模块与全局变量的作用域管理
从OpenAI API响应中高效提取生成文本
在Runstone环境中高效处理TasteDive API的JSON数据
谷歌浏览器最新官方入口链接 谷歌浏览器网页版官网导航
C++20的source_location是什么_C++在编译期获取源码位置信息用于日志和断言
vivo手机参数配置怎么增强信号_vivo手机参数配置信号增强方法
支付宝如何管理隐私设置_支付宝隐私保护的配置技巧
利用Bokeh CustomJS动态控制DataTable列可见性
Lar*el Excel导入时生成自定义递增ID的策略与实践
J*aScript DOM操作:高效清空列表元素的策略与实践
蓝湖怎样用切图标注提对接效率_蓝湖用切图标注提对接效率【设计对接】
深入理解J*aScript Promise异步执行与微任务队列
神庙逃亡小游戏在线玩 神庙逃亡小游戏入口
Excel文件在线转换快速入口 Excel在线格式转换网站
C++如何使用AddressSanitizer(ASan)_C++调试工具中检测内存访问错误的利器
word邮件合并后日期格式不对怎么改_Word邮件合并日期格式修改方法
163邮箱官方主页登录 直达网易邮箱登录核心页面
React Hooks最佳实践:动态组件状态管理的组件化方案
12306选座系统怎么选连座_12306选座多人连坐操作方法
极速漫画官方主页网址 极速漫画漫画在线浏览官网链接
Fabric Mod开发:在1.19.3+版本中正确添加自定义物品并管理物品组
解决Rails应用中内容错位与Turbo警告:meta标签误用导致富文本渲染异常
《GTA6》开发画面疑似泄露!这次可不是AI了
响应式CSS Grid布局:优化网格项在小屏幕下的堆叠与宽度适配
如何高效处理PHP中的Excel数据导入导出?PortPHP/Spreadsheet助你轻松搞定!
QQ网页版官方账号入口 QQ网页版网页版登录指南
Sublime怎么配置Nim语言环境_Sublime Nim代码高亮与补全
电脑IP地址怎么查 查看本机IP地址的几种方法
谷歌学术网站直达地址 谷歌学术搜索网页版一键进入
J*aScript 字符串标签转换:使用正则表达式高效替换
圆通快递查询实时追踪 圆通物流包裹状态快速查看
Angular响应式表单:实现提交后表单及按钮的禁用与只读化
Yandex搜索引擎官网入口_俄罗斯Yandex免登录一键直达
谷歌浏览器无痕模式怎么开 Chrome开启无痕浏览设置方法【教程】
PySpark中高效提取字符串右侧可变长度数字:使用regexp_extract


2025-10-24
浏览次数:次
返回列表
<div class="row">
<div class="col-md-12">
<h1>第五部分</h1>
<p>这是第五部分的内容。</p>
<div class="aritcle_card">
<a class="aritcle_card_img" href="/ai/1125">
<img src="https://img.php.cn/upload/ai_manual/000/000/000/175680079579055.png" alt="OneStory">
</a>
<div class="aritcle_card_info">
<a href="/ai/1125">OneStory</a>
<p>OneStory 是一款创新的AI故事生成助手,用AI快速生成连续性、一致性的角色和故事。</p>
<div class="">
<img src="/static/images/card_xiazai.png" alt="OneStory">
<span>319</span>
</div>
</div>
<a href="/ai/1125" class="aritcle_card_btn">
<span>查看详情</span>
<img src="/static/images/cardxiayige-3.png" alt="OneStory">
</a>
</div>
</div>
</div>
</div>
</section>
</div>
<script src="script.js"></script>
</body>
</html>