CSS3实现整屏切换效果

2024-06-06 08:08

本文主要是介绍CSS3实现整屏切换效果,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

总是能看见很多广告或者网站都是使用整屏滚动的效果,一直看着都心痒痒,想自己也实现一个。最近刚学习到css3的动画效果,所以尝试使用css3做了一个整屏切换。

页面结构

实现思路与大众方法类似,如图
这里写图片描述
每个section就是一页内容,它的大小充满了屏幕(红色区域),一个container由多个section构成,我们通过改变container的位置,来达到页面切换的效果。container向下走,页面好像上移了,container向上走,页面就下移了。
html结构如下:

<!DOCTYPE html>
<html>
<head lang="ch"><meta charset="UTF-8"><!--适配移动端--><meta name=”viewport” content="width=device-width, user-scalable=no, initial-scale=1.0"><title></title><style>body, html{padding: 0;margin: 0;}body, html {height: 100%;/**隐藏滚动条**/overflow: hidden;}#container, .section {height: 100%;}#section0 {background-color: #83af9b;}#section1 {background-color: #764d39;}#section2 {background-color: #ff9000;}#section3 {background-color: #380d31;}</style>
</head>
<body>
<div id="container"><div class="section" id="section0"></div><div class="section" id="section1"></div><div class="section" id="section2"></div><div class="section" id="section3"></div>
</div>
</body>
</html>

事件监听

此时窗口里只显示一个页面,我们给其加上滚动监听,因为firefox和非firefox浏览器对滚动监听支持不同,firefox浏览器向上滚动是-120,向下滚动是120,而其他浏览器向上是5,向下是-5,所以需要作判断:

<script src="http://code.jquery.com/jquery-latest.js"></script>
<script>//当前页面索引var curIndex = 0;var scrollFunc = function (e) {e = e || window.event;var t = 0;if (e.wheelDelta) {//IE/Opera/Chromet = e.wheelDelta;if (t > 0 && curIndex > 0) {//上滚动movePrev();} else if (t < 0 && curIndex < sumCount - 1) {//下滚动moveNext();}} else if (e.detail) {//Firefoxt = e.detail;if (t < 0 && curIndex > 0) {//上滚动movePrev();} else if (t > 0 && curIndex < sumCount - 1) {//下滚动moveNext();}}};function moveNext(){}function movePrev(){}function init(){/*注册事件*/if (document.addEventListener) {document.addEventListener('DOMMouseScroll', scrollFunc, false);}//W3Cwindow.onmousewheel = document.onmousewheel = scrollFunc;//IE/Opera/Chrome}init();
</script>

为了防止在第一个页面用户上滚,最后一个页面用户下滚,所以用curIndex代表当前页面索引在滚动时作了监听,当然如果要使页面循环滚动,只需修改条件限制即可。

加入动画

动画使用到了css3里的transform属性的translate3D,我们首先需要获取到屏幕的高度,然后当页面切换的时候将container上移一个屏幕高度或下移一个屏幕高度。
使用translate3D的原因是在手机端会开启硬件加速,使动画更流畅,它接收三个参数,分别是x轴、y轴和z轴的位移。如

transform: tanslate3D(10px, 30px, 0);

修改后的js代码如下:

<script>//当前页面索引var curIndex = 0;//container元素var container = $("#container");//页面总数var sumCount = $(".section").length;//窗体元素var $window = $(window);//动画时间var duration = 500;var scrollFunc = function (e) {e = e || window.event;var t = 0;if (e.wheelDelta) {//IE/Opera/Chromet = e.wheelDelta;if (t > 0 && curIndex > 0) {//上滚动movePrev();} else if (t < 0 && curIndex < sumCount - 1) {//下滚动moveNext();}} else if (e.detail) {//Firefoxt = e.detail;if (t < 0 && curIndex > 0) {//上滚动movePrev();} else if (t > 0 && curIndex < sumCount - 1) {//下滚动moveNext();}}};function moveNext(){container.css("transform", "translate3D(0, -" + (++curIndex) * $window.height() + "px, 0)");}function movePrev(){container.css("transform", "translate3D(0, -" + (--curIndex) * $window.height() + "px, 0)");}function init(){/*注册事件*/if (document.addEventListener) {document.addEventListener('DOMMouseScroll', scrollFunc, false);}//W3Cwindow.onmousewheel = document.onmousewheel = scrollFunc;//IE/Opera/Chrome//设置动画container.css({"transition": "all 0.5s","-moz-transition": "all 0.5s","-webkit-transition": "all 0.5s"});}
</script>

为了防止页面在滚动的时候用户继续滚动打乱节奏,可以用时间来强制控制,即在滚动期间不允许调用moveNext和movePrev函数,最终代码如下:

<!DOCTYPE html>
<html>
<head lang="ch"><meta charset="UTF-8"><meta name=”viewport” content="width=device-width, user-scalable=no, initial-scale=1.0"><title></title><style>body, html{padding: 0;margin: 0;}body, html {height: 100%;overflow: hidden;}#container, .section {height: 100%;}.section {background-color: #000;background-size: cover;background-position: 50% 50%;}#section0 {background-color: #83af9b;}#section1 {background-color: #764d39;}#section2 {background-color: #ff9000;}#section3 {background-color: #380d31;}</style>
</head>
<body>
<div id="container"><div class="section" id="section0"></div><div class="section" id="section1"></div><div class="section" id="section2"></div><div class="section" id="section3"></div>
</div><script src="http://code.jquery.com/jquery-latest.js"></script>
<script>var curIndex = 0;var container = $("#container");var sumCount = $(".section").length;var $window = $(window);var duration = 500;//时间控制var aniTime = 0;var scrollFunc = function (e) {//如果动画还没执行完,则returnif(new Date().getTime() < aniTime + duration){return;}e = e || window.event;var t = 0;if (e.wheelDelta) {//IE/Opera/Chromet = e.wheelDelta;if (t > 0 && curIndex > 0) {//上滚动movePrev();} else if (t < 0 && curIndex < sumCount - 1) {//下滚动moveNext();}} else if (e.detail) {//Firefoxt = e.detail;if (t < 0 && curIndex > 0) {//上滚动movePrev();} else if (t > 0 && curIndex < sumCount - 1) {//下滚动moveNext();}}};function moveNext(){//获取动画开始时的时间aniTime = new Date().getTime();container.css("transform", "translate3D(0, -" + (++curIndex) * $window.height() + "px, 0)");}function movePrev(){//获取动画开始时的时间aniTime = new Date().getTime();container.css("transform", "translate3D(0, -" + (--curIndex) * $window.height() + "px, 0)");}function init(){/*注册事件*/if (document.addEventListener) {document.addEventListener('DOMMouseScroll', scrollFunc, false);}//W3Cwindow.onmousewheel = document.onmousewheel = scrollFunc;//IE/Opera/Chromecontainer.css({"transition": "all 0.5s","-moz-transition": "all 0.5s","-webkit-transition": "all 0.5s"});}init();
</script>
</body>
</html>

这篇关于CSS3实现整屏切换效果的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1035545

相关文章

Redis实现高效内存管理的示例代码

《Redis实现高效内存管理的示例代码》Redis内存管理是其核心功能之一,为了高效地利用内存,Redis采用了多种技术和策略,如优化的数据结构、内存分配策略、内存回收、数据压缩等,下面就来详细的介绍... 目录1. 内存分配策略jemalloc 的使用2. 数据压缩和编码ziplist示例代码3. 优化的

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

Java Kafka消费者实现过程

《JavaKafka消费者实现过程》Kafka消费者通过KafkaConsumer类实现,核心机制包括偏移量管理、消费者组协调、批量拉取消息及多线程处理,手动提交offset确保数据可靠性,自动提交... 目录基础KafkaConsumer类分析关键代码与核心算法2.1 订阅与分区分配2.2 拉取消息2.3

SpringBoot集成XXL-JOB实现任务管理全流程

《SpringBoot集成XXL-JOB实现任务管理全流程》XXL-JOB是一款轻量级分布式任务调度平台,功能丰富、界面简洁、易于扩展,本文介绍如何通过SpringBoot项目,使用RestTempl... 目录一、前言二、项目结构简述三、Maven 依赖四、Controller 代码详解五、Service

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.