Javascript幻灯片播放功能实现过程解析


Posted in Javascript onMay 07, 2020

javascript实现幻灯片播放

实现原理

  • step1 设置容器,包含图片、翻页、下标等元素,通过相对定位来布局。
  • step2 将幻灯片变化,需要改变的元素放在一个字容器内,display设为none,并且采取动画来变化。
  • step3设置js函数,将应该播放的元素样式激活,其他的元素仍为未激活状态或者不展示类的隐藏。

代码

html

<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title>Insert title here</title>
<!-- 引入css样式 -->
<link rel="stylesheet" href="style.css" rel="external nofollow" type="text/css">

</head>
<body>
	<!-- 先设置轮播的整体容器 -->
	<div class="slideshow-container">
		<!-- 在设置轮播图片、翻页键、数字文本的容器 -->
		<!-- fade为滑动动画特效 -->
		<div class="mySlides fade">
			<div class="numbertext">1 / 3</div>
			<img src="img/1.jpg" style="width: 100%">
			<div class="text">文本 1</div>
		</div>

		<div class="mySlides fade">
			<div class="numbertext">2 / 3</div>
			<img src="img/2.jpg" style="width: 100%">
			<div class="text">文本 2</div>
		</div>

		<div class="mySlides fade">
			<div class="numbertext">3 / 3</div>
			<img src="img/3.jpg" style="width: 100%">
			<div class="text">文本 3</div>
		</div>
		
		<a class="prev" onclick="plusSlides(-1)">❮</a> 
		<a class="next" onclick="plusSlides(1)">❯</a>
	</div>
	<br>
	<!-- 设置下方按钮 -->
	<div style="text-align: center">
		<span class="dot" onclick="currentSlide(1)"></span>
		<span class="dot" onclick="currentSlide(2)"></span>
		<span class="dot" onclick="currentSlide(3)"></span>
	</div>
  <!-- 引入js文件,注意js文件应该在下方,否则将无法出现错误,个人觉得错误原因应该是元素未加载而去执行js文件导致错误,具体原因还需探究-->
	<script src="show.js" type="text/javascript"></script>
</body>

</html>

css

@charset "UTF-8";
* {box-sizing:border-box}
body {font-family: Verdana,sans-serif;}
.mySlides {
	display:none;
  /*display 为none的含义是不展示元素,但是且不占用空间*/
}
/* 幻灯片容器 */
.slideshow-container {
 max-width: 1000px;
 position: relative;
 margin: auto;
}

/* 下一张 & 上一张 按钮 */
.prev, .next {
 cursor: pointer;
 position: absolute;
 top: 50%;
 width: auto;
 margin-top: -22px;
 padding: 16px;
 color: white;
 font-weight: bold;
 font-size: 18px;
 transition: 0.6s ease;
 border-radius: 0 3px 3px 0;
}

/* 定位 "下一张" 按钮靠右 */
.next {
 right: 0;
 border-radius: 3px 0 0 3px;
}

/* On hover, add a black background color with a little bit see-through */
.prev:hover, .next:hover {
 background-color: rgba(0,0,0,0.8);
}

/* 标题文本 */
.text {
 color: #f2f2f2;
 font-size: 15px;
 padding: 8px 12px;
 position: absolute;
 bottom: 8px;
 width: 100%;
 text-align: center;
}

/* 数字文本 (1/3 等) */
.numbertext {
 color: #f2f2f2;
 font-size: 12px;
 padding: 8px 12px;
 position: absolute;
 top: 0;
}

/* 标记符号 */
.dot {
 cursor:pointer;
 height: 13px;
 width: 13px;
 margin: 0 2px;
 background-color: #bbb;
 border-radius: 50%;
 display: inline-block;
 transition: background-color 0.6s ease;
}

.active, .dot:hover {
 background-color: #717171;
}

/* 淡出动画 */
.fade {
 -webkit-animation-name: fade;
 -webkit-animation-duration: 1.5s;
 animation-name: fade;
 animation-duration: 1.5s;
}

@-webkit-keyframes fade {
 from {opacity: .4} 
 to {opacity: 1}
}

@keyframes fade {
 from {opacity: .4} 
 to {opacity: 1}
}

js

var slideIndex = 1;

function plusSlides(n) {
 showSlides(slideIndex += n);
}

function currentSlide(n) {
 showSlides(slideIndex = n);
}

function showSlides(n) {
 var i;
 var slides = document.getElementsByClassName("mySlides");
 var dots = document.getElementsByClassName("dot");
 if (n > slides.length) {slideIndex = 1} 
 if (n < 1) {slideIndex = slides.length}
 for (i = 0; i < slides.length; i++) {
   slides[i].style.display = "none"; 
 }//class为mySlides下的元素,即不展示项目的图片元素、数字元素和文本元素
 for (i = 0; i < dots.length; i++) {
   dots[i].className = dots[i].className.replace(" active", "");//将激活的下标元素,改为不再展示
 }
 slides[slideIndex-1].style.display = "block";//轮播的元素展示 
 dots[slideIndex-1].className += " active";//轮播图片对应下标样式激活
}
showSlides(slideIndex);

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 异步调用框架 (Part 3 - 代码实现)
Aug 04 Javascript
关于js日期转化为毫秒数“节省20%的效率和和节省9个字符“问题
Mar 01 Javascript
node.js中的fs.writeSync方法使用说明
Dec 15 Javascript
javascript 获取浏览器版本
Jan 21 Javascript
JavaScript定时显示广告代码分享
Mar 02 Javascript
JavaScript设置表单上传时文件个数的方法
Aug 11 Javascript
微信+angularJS的SPA应用中用router进行页面跳转,jssdk校验失败问题解决
Sep 09 Javascript
JavaScript鼠标特效大全
Sep 13 Javascript
原生JS下拉加载插件分享
Dec 26 Javascript
vue实例中data使用return包裹的方法
Aug 27 Javascript
angularjs下ng-repeat点击元素改变样式的实现方法
Sep 12 Javascript
vue封装一个简单的div框选时间的组件的方法
Jan 06 Javascript
基于javascript实现日历功能原理及代码实例
May 07 #Javascript
Vue简单实现原理详解
May 07 #Javascript
angular组件间通讯的实现方法示例
May 07 #Javascript
基于better-scroll 实现歌词联动功能的代码
May 07 #Javascript
Vue双向绑定实现原理与方法详解
May 07 #Javascript
JavaScript设计模式之观察者模式与发布订阅模式详解
May 07 #Javascript
微信小程序pinker组件使用实现自动相减日期
May 07 #Javascript
You might like
php 提速工具eAccelerator 配置参数详解
2010/05/16 PHP
php下统计用户在线时间的一种尝试
2010/08/26 PHP
PHP flock 文件锁详细介绍
2012/12/29 PHP
显示程序执行时间php函数代码
2013/08/29 PHP
php jq jquery getJSON跨域提交数据完整版
2013/09/13 PHP
PHP使用Mysql事务实例解析
2014/09/08 PHP
php生成二维码时出现中文乱码的解决方法
2014/12/18 PHP
PHP开启opcache提升代码性能
2015/04/26 PHP
PHP将英文数字转换为阿拉伯数字实例讲解
2019/01/28 PHP
图片img的src不变让浏览器重新加载实现方法
2013/03/29 Javascript
JavaScript中实现依赖注入的思路分享
2015/01/15 Javascript
ajax+jQuery实现级联显示地址的方法
2015/05/06 Javascript
JS给Textarea文本框添加行号的方法
2015/08/20 Javascript
JavaScript使用小插件实现倒计时的方法讲解
2019/03/11 Javascript
用jQuery实现抽奖程序
2020/04/12 jQuery
JS实现无限轮播无倒退效果
2020/09/21 Javascript
vue-openlayers实现地图坐标弹框效果
2020/09/24 Javascript
JavaScript中条件语句的优化技巧总结
2020/12/04 Javascript
vuex的使用和简易实现
2021/01/07 Vue.js
在Python程序中操作文件之flush()方法的使用教程
2015/05/24 Python
利用python批量给云主机配置安全组的方法教程
2017/06/21 Python
Tensorflow 训练自己的数据集将数据直接导入到内存
2018/06/19 Python
PyCharm中Matplotlib绘图不能显示UI效果的问题解决
2020/03/12 Python
Python学习之os模块及用法
2020/06/03 Python
python分布式爬虫中消息队列知识点详解
2020/11/26 Python
利用Python函数实现一个万历表完整示例
2021/01/23 Python
全球度假村:Club Med
2017/11/27 全球购物
Timberland德国官网:靴子、鞋子、衣服、夹克及配件
2019/12/10 全球购物
thinkphp5 redis缓存新增方法实例讲解
2021/03/24 PHP
中级会计职业生涯规划范文
2014/01/16 职场文书
承认错误的检讨书
2014/01/30 职场文书
保护环境演讲稿
2014/05/10 职场文书
毕业生自我鉴定范文
2019/05/13 职场文书
Django使用redis配置缓存的方法
2021/06/01 Redis
Apache Pulsar集群搭建部署详细过程
2022/02/12 Servers
Django框架中模型的用法
2022/06/10 Python