文档章节

纯js 轮播的封装

静水流深01
 静水流深01
发布于 2017/04/26 19:00
字数 567
阅读 57
收藏 1
<!DOCTYPE html>
<html>

	<head>
		<meta charset="UTF-8">
		<title></title>
		<style type="text/css">
			body,
			ul,
			li {
				padding: 0;
				margin: 0;
			}
			
			.carouselBox {
				width: 512px;
				height: 384px;
				border: 3px solid black;
				margin: 0 auto;
				position: relative;
			}
			
			.carouselBox ul {
				position: absolute;
				left: 50%;
				transform: translateX(-50%);
				bottom: 10px;
				z-index: 2;
				overflow: hidden;
			}
			
			.carouselBox ul li {
				list-style: none;
				cursor: pointer;
				-moz-user-select: none;
				user-select: none;
				width: 18px;
				height: 18px;
				font-size: 14px;
				line-height: 18px;
				text-align: center;
				background: #ccc;
				float: left;
				margin: 2px;
			}
			
			.carouselBox ul li.selected {
				background: orange;
			}
			
			.carouselBox ul li.normal {
				background: #ccc;
			}
			
			.carouselBox button {
				position: absolute;
				top: 50%;
				transform: translateY(-50%);
				font-size: 40px;
				font-weight: 200;
				opacity: 0;
			}
			
			.carouselBox button.show {
				opacity: .7;
			}
			
			.carouselBox .btnL {
				left: 10px;
			}
			
			.carouselBox .btnR {
				right: 10px;
			}
		</style>
	</head>

	<body>
		<div class="carouselBox" id="carouselBox">
			<img class="carouselImg" src="images/1.jpg" alt="" />
			<ul>
				<li class="selected">1</li>
				<li>2</li>
				<li>3</li>
				<li>4</li>
				<li>5</li>
				<li>6</li>
			</ul>
			<button class="btnL">&lt;</button>
			<button class="btnR">&gt;</button>
		</div>
		<script type="text/javascript">
			//获取轮播盒字元素节点
			var carouselBox = document.getElementById("carouselBox");

			//调用轮播
			carousel(carouselBox);
			//封装轮播
			function carousel(carouselBox) {

				var carouselBox = carouselBox;
				//获取轮播图片节点
				var carouselImg = carouselBox.getElementsByClassName("carouselImg")[0];
				//获取到所以轮播按钮节点
				var lis = carouselBox.getElementsByTagName("li");
				var len = lis.length;
				//左点击按钮
				var btnL = carouselBox.getElementsByClassName("btnL")[0];
				//右点击按钮
				var btnR = carouselBox.getElementsByClassName("btnR")[0];
				//定义默认图片
				var autoImg = 1;
				//定时器
				var time = null;
				//当前li下标值
				var currIndex = null;
				//调用自动轮播
				autoCarousel();
				//调用点击轮播
				clickCarousel();

				//自动轮播
				function autoCarousel() {
					time = setInterval(autoChange, 1000);
				}
				//自动切换函数
				function autoChange() {
					//如果是最后一张变成第一张
					if(autoImg == 6) {
						autoImg = 1;
					} else {
						autoImg++;
					}
					carouselImg.src = "images/" + autoImg + ".jpg";

					//对应得按钮背景色改变
					bgChange(autoImg - 1);
				}

				//背景色改变函数
				function bgChange(t) {

					for(var i = 0; i < len; i++) {
						if(i === t) {
							//如果是和当前图片对应得下标的li则改变背景 否则变为正常的
							lis[i].className = "selected";
						} else {
							lis[i].className = "normal";
						}
					}
				}

				//点击轮播
				function clickCarousel() {
					for(var i = 0; i < len; i++) {
						lis[i].onclick = function() {
							currIndex = getIndex(this);
							bgChange(currIndex);
							carouselImg.src = "images/" + (currIndex + 1) + ".jpg";
							autoImg = currIndex;
						}
					}
				}

				//获取到点击li的下标
				function getIndex(t) {
					//定义个标签
					var index = -1;
					for(var i = 0; i < len; i++) {
						//找到当前点击对象 并记录下标值
						if(lis[i] === t) {
							index = i;
							break;
						}
					}
					return index;
				}
				//鼠标移入的时候清楚定时器
				carouselBox.onmouseenter = function() {
					clearTimeout(time);
					btnL.className = "show btnL";
					btnR.className = "show btnR";
				}
				//鼠标移出继续轮播
				carouselBox.onmouseleave = function() {
					autoCarousel();
					btnL.className = "btnL";
					btnR.className = "btnR";
				}
				//左点击按钮事件
				btnL.onclick = function() {
					currIndex = autoImg;
					if(autoImg == 1) {
						autoImg = 6;
					} else {
						autoImg--;
					}
					carouselImg.src = "images/" + autoImg + ".jpg";

					//对应得按钮背景色改变
					bgChange(autoImg - 1);
				}
				//右按钮点击事件
				btnR.onclick = function() {
					currIndex = autoImg;
					autoChange();
				}
			}
		</script>
	</body>

</html>

© 著作权归作者所有

共有 人打赏支持
静水流深01
粉丝 3
博文 15
码字总数 14681
作品 0
信阳
程序员
记一个JavaScript图片轮播思路与代码

说在前头 喜欢并学习前端,一路摸爬滚打过来,现在算算也快满一年的,每天或多或少都会来“拜读”大家的写的文章,学习与感悟了不少,作为一名要变的更强的前端小哥哥,在这个节点上,也想写...

柚子先生
08/06
0
0
封装一个简单的原生js焦点轮播图插件

轮播图实现的效果为,鼠标移入左右箭头会出现,可以点击切换图片,下面的小圆点会跟随,可以循环播放。本篇文章的主要目的是分享封装插件的思路。 轮播图的我一开始是写成非插件形式实现的效...

daisy,gogogo
08/18
0
0
手把手教你封装JavaScript插件

我们可能已经用过很多JS插件,比如著名的轮播图插件Swiper.js,滚动条插件iScroll.js等等,用起来非常方便,大大提高了我们的工作效率。那么它们基本实现原理是怎样的呢?我们又该如何DIY一个...

前端王睿
08/29
0
0
最近排查android webview https的发热耗电和加载速度慢问题解决

最近排查android webview https的发热耗电和加载速度慢问题 问题:H5页面发热耗电 排查:通过android studio profiler 查看CPU消耗曲线,发现静置情况下webview轮播图波浪式消耗CPU,且峰值高...

ljianbing
05/28
0
0
手把手教你用原生JavaScript造轮子(2)——轮播图

通过上一篇文章的学习,我们基本掌握了一个轮子的封装和开发流程。那么这次将带大家开发一个更有难度的项目——轮播图,希望能进一步加深大家对于面向对象插件开发的理解和认识。 So, Let's ...

csdoker
08/12
0
0

没有更多内容

加载失败,请刷新页面

加载更多

你为什么在Redis里读到了本应过期的数据

一个事故的故事 晚上睡的正香突然被电话吵醒,对面是开发焦急的声音:我们的程序在访问redis的时候读到了本应过期的key导致整个业务逻辑出了问题,需要马上解决。 看到这里你可能会想:这是不...

IT--小哥
今天
2
0
祝大家节日快乐,阖家幸福! centos GnuTLS 漏洞

yum update -y gnutls 修复了GnuTLS 漏洞。更新到最新 gnutls.x86_64 0:2.12.23-22.el6 版本

yizhichao
昨天
5
0
Scrapy 1.5.0之选择器

构造选择器 Scrapy选择器是通过文本(Text)或 TextResponse 对象构造的 Selector 类的实例。 它根据输入类型自动选择最佳的解析规则(XML vs HTML): >>> from scrapy.selector import Sele...

Eappo_Geng
昨天
4
0
Windows下Git多账号配置,同一电脑多个ssh-key的管理

Windows下Git多账号配置,同一电脑多个ssh-key的管理   这一篇文章是对上一篇文章《Git-TortoiseGit完整配置流程》的拓展,所以需要对上一篇文章有所了解,当然直接往下看也可以,其中也有...

morpheusWB
昨天
5
0
中秋快乐!!!

HiBlock
昨天
3
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部