【前端】javascript实现带有子菜单和控件的轮播图slider

实现效果:

实现原理:

// 步骤
// 1. 获取事件源以及相关元素
// 2. 复制第一张图片所在的li,添加到ul的最后面
// 3. 给ol添加li,ul中的个数-1个,并点亮第一个按钮
// 4. 鼠标放到ol的li上切换图片
// 5. 添加定时器
// 6. 左右切换图片(鼠标放上去隐藏,移开显示)

实现代码:

<!DOCTYPE html>
<html>
<head>
	<title>轮播图</title>
	<meta charset="utf-8">
	<style type="text/css">
		*{
			padding: 0;
			margin: 0;
			list-style: none;
			border: 0;
		}
		.all{
			width: 500px;
			height: 200px;
			padding: 7px;
			margin: 100px auto;
			position: relative;
			box-shadow: 1px 1px 5px #2d2d2d;
		}
		.screen{
			width: 500px;
			height: 200px;
			overflow: hidden;
			position: relative;
		}
		.screen li{
			width: 500px;
			height: 200px;
			overflow: hidden;
			float: left;
		}
		.screen ul{
			position: absolute;
			left: 0;
			top: 0;
			width: 3000px;
		}
		.all ol{
			position: absolute;
			right: 10px;
			bottom: 10px;
			line-height: 20px;
			text-align: center;
		}
		.all ol li{
			float: left;
			width: 20px;
			height: 20px;
			text-align: center;
			background-color: #fff;
			border: 1px solid #ccc;
			margin-left: 10px;
			cursor: pointer;
		}
		.all ol li.current{
			background-color: #03c03c;
		}
		#arr{
			display: none;
		}
		#arr span{
			width: 40px;
			height: 40px;
			left: 5px;
			top: 50%;
			position: absolute;
			margin-top: -20px;
			background-color: #000;
			cursor: pointer;
			line-height: 35px;
			text-align: center;
			font-weight: bold;
			font-family: "微软雅黑";
			font-size: 30px;
			color: #fff;
			opacity: 0.3;
			border-radius: 50%;
			box-shadow: 1px 1px 3px #2d2d2d;
		}
		#arr #right{
			right: 5px;
			left: auto;
		}
	</style>
</head>
<body>
<div class="all" id="all">
	<div class="screen" id="screen">
		<ul id="ul">
			<li><img src="./images/01.jpg" width="500" height="200"></li>
			<li><img src="./images/02.jpg" width="500" height="200"></li>
			<li><img src="./images/03.jpg" width="500" height="200"></li>
			<li><img src="./images/04.jpg" width="500" height="200"></li>
			<li><img src="./images/05.jpg" width="500" height="200"></li>
		</ul>
		<!-- 图片子菜单 -->
		<ol>

		</ol>
		<!-- 左右切换按钮 -->
		<div id="arr">
			<span id="left"><</span>
			<span id="right">></span>
		</div>
	</div>
</div>

<!-- script -->
<script type="text/javascript">
	// 赋值第一张图片放到ul的最后,当图片切换到第五张的时候,直接切换第六张,再从第一张切换到第二张的时候先瞬间切换到第一张图片,然后滑倒第二张

	// 步骤
	// 1. 获取事件源以及相关元素
	// 2. 复制第一张图片所在的li,添加到ul的最后面
	// 3. 给ol添加li,ul中的个数-1个,并点亮第一个按钮
	// 4. 鼠标放到ol的li上切换图片
	// 5. 添加定时器
	// 6. 左右切换图片(鼠标放上去隐藏,移开显示)

	// 1. 获取事件源以及相关元素
	var all = document.getElementById("all");
	var screen = all.firstElementChild || all.firstChild;
	var imgWidth = screen.offsetWidth;
	var ul = screen.firstElementChild || screen.firstChild;
	var ol = screen.children[1];
	var div = screen.lastElementChild || screen.lastChild;
	var spanArr = div.children;

	// 2. 复制第一张图片所在的li,添加到ul的最后面
	var ulNewLi = ul.children[0].cloneNode(true);
	ul.appendChild(ulNewLi);

	// 3. 给ol添加li,ul中的个数-1个,并点亮第一个按钮
	for(var i=0; i<ul.children.length-1; i++){
		var olNewLi = document.createElement("li");
		olNewLi.innerHTML = i+1;
		ol.appendChild(olNewLi);
	}
	var olLiArr = ol.children;
	olLiArr[0].className = "current";

	// 4. 鼠标放到ol的li上切换图片
	for(var i=0; i<olLiArr.length; i++){
		// 自定义属性,把索引值绑定到元素的index属性上
		olLiArr[i].index = i;
		olLiArr[i].onmouseover = function(){
			// 排他思想
			for(var j=0; j<olLiArr.length; j++){
				olLiArr[j].className = "";
			}
			this.className = "current"
			// 鼠标放到小方块上时,索引值和key以及square同步
			// key = this.index;
			// square = this.index;
			key = square = this.index;
			// 移动盒子
			animate(ul, -this.index*imgWidth);
		}
	}

	// 5. 添加定时器
	var timer = setInterval(autoPlay, 1000);

	// 固定向右切换图片
	// 两个定时器(一个记录图片,一个记录子菜单栏)
	var key = 0;
	var square = 0;
	function autoPlay(){
		// 通过key的自增来模拟图片的索引值,然后移动ul
		key++;
		if(key > olLiArr.length){
			// 图片已经滑到最后一张,接下来应该跳转到第一张,然后滑动到第二张
			ul.style.left = 0;
			key = 1;
		}
		animate(ul, -key*imgWidth);
		// 通过控制square的自增来模拟小方块的索引值,然后点亮盒子
		// 排他思想做小方块
		square++;
		if(square > olLiArr.length-1){
			// 索引值不能大于5,如果大于5则立即变为0;
			square = 0;
		}
		for(var i=0; i<olLiArr.length; i++){
			olLiArr[i].className = "";
		}
		olLiArr[square].className = "current";
	}

	// 鼠标放上去清除定时器,移开启动定时器
	all.onmouseover = function(){
		div.style.display = "block";
		clearInterval(timer);
	}
	all.onmouseout = function(){
		div.style.display = "none";
		timer = setInterval(autoPlay,1000);
	}

	// 6. 左右切换图片(鼠标放上去显示,移开隐藏)
	spanArr[0].onclick = function(){
		// 通过控制key的自增来模拟图片的索引值,然后移动ul
		key--;
		if(key<0){
			// 先移到最后一张,然后key的值取前一张的索引值,然后向前移动
			ul.style.left = -imgWidth*(olLiArr.length) + "px";
			key = olLiArr.length-1;
		}
		animate(ul, -key*imgWidth);
		// 通过控制square的自增来模拟小方块的索引值,然后点亮小方块
		square--;
		if(square<0){
			// 索引值不能大于等于5,如果为5,立即变为0
			square = olLiArr.length-1;
		}
		for(var i=0; i<olLiArr.length; i++){
			olLiArr[i].className = "";
		}
		olLiArr[square].className = "current";
	}

	spanArr[1].onclick = function(){
		// 右侧的和定时器一模一样
		autoPlay();
	}

	// 动画封装
	var absSpeed = 10; //设定步长
	function animate(ele, target){
		clearInterval(ele.timer);
		var speed = target > ele.offsetLeft ? absSpeed : -absSpeed;
		ele.timer = setInterval(function(){
			var val = target - ele.offsetLeft;
			ele.style.left = ele.offsetLeft + speed + "px";
			if(Math.abs(val) < Math.abs(speed)){
				ele.style.left = target + "px";
				clearInterval(ele.timer);
			}
		}, 10)
	}
</script>
</body>
</html>

  

时间: 2024-08-13 18:15:15

【前端】javascript实现带有子菜单和控件的轮播图slider的相关文章

Android自己定义控件之轮播图控件

背景 近期要做一个轮播图的效果.网上看了几篇文章.基本上都能找到实现,效果还挺不错,可是在写的时候感觉每次都要单独去又一次在Activity里写一堆代码.于是自己封装了一下.这里仅仅是做了下封装成一个控件,不必每次反复写代码了. 效果图 实现分析 轮播图的功能就是实现左右滑动的广告.图片信息展示,那我们就用ViewPager来实现,由于考虑到用户体验,我们还须要在以下加一个指示器来标示滑动到了第几张轮播图.指示器我们能够用一个线性布局来依据要展示的轮播图设置显示的View,我们要做这种一个控件没

【前端】javascript+jQuery实现旋转木马效果轮播图slider

实现效果: 实现原理: 技术栈: javascript+jQuery+html+css 实现步骤: // 0. 获取元素 // 1. 鼠标放置到轮播图上,显示两侧的控制按钮,移开后隐藏 // 2. 为两侧控制按钮绑定事件(调用同一个方法,只有一个参数,true为正向旋转,false为反向旋转) 实现代码: <!DOCTYPE html> <html> <head> <title>旋转木马效果轮播图</title> <meta charset

JQuery和html+css实现带小圆点和左右按钮的轮播图

是的!你没看错!还是轮播图.这次的JQuery的哟!! CSS代码: /*轮播图 左右按钮 小白点*/ #second_div{ margin-top: 160px; } .img_box{ overflow: hidden; width:100%; height:420px; border:1px solid; position:relative; } .img_box img{ width:100%; position:absolute; } .ul5{ list-style: none;

JavaScript:100%原生js实现左右切换的轮播图(有延迟加载)

<!--说明:此.html文件必需有:(1)同级文件夹json,json文件夹下必需有文件data.txt,文件data.txt的内容为: [{"imgSrc":"img/banner1.jpg"}, {"imgSrc":"img/banner2.jpg"}, {"imgSrc":"img/banner3.jpg"}, {"imgSrc":"img/b

JavaScript:100%原生js实现左右切换的轮播图(无延迟加载)

<!--说明:此.html文件必需有:(1)同级文件夹json,json文件夹下必需有文件data.txt,文件data.txt的内容为: [{"imgSrc":"img/banner1.jpg"}, {"imgSrc":"img/banner2.jpg"}, {"imgSrc":"img/banner3.jpg"}, {"imgSrc":"img/b

Android侧滑菜单和轮播图之滑动冲突

接手一个项目,有一个问题需要修改:轮播图不能手动滑动,手动滑动轮播图只会触发侧滑菜单. 猜测:viewpager控件(轮播图)的触摸事件被SlidingMenu控件(侧滑菜单,非第三方项目,乃是上个开发人员自定义的)拦截了. 基于这个猜测,我自定义一个ViewPager,重写dispatchTouchEvent.onInterceptTouchEvent和onTouchEvent,分别在这三个方法中打印log: 重写SlidingMenu的dispatchTouchEvent.onInterce

C# 带滚动条的Label控件

C# 带滚动条的Label控件,用鼠标选的时候还是有点闪烁: namespace 带滚动条的Label控件 { public class TextBoxLabel : System.Windows.Forms.TextBox { [DllImport("user32", EntryPoint = "HideCaret")] private static extern bool HideCaret(IntPtr hWnd); [DllImport("user

Atitit.ui控件---下拉菜单选择控件的实现select html

Atitit.ui控件---下拉菜单选择控件的实现select   html 1. 调用& model的实现 1 2. -----select.jsp------ 1 1. 调用& model的实现 Proj.vod2 <% List li=new ArrayList(); Map m=new HashMap (); m.put("lab","爱情"); m.put("v","1"); li.add(m)

如何通过JavaScript构建Asp.net服务端控件

摘要 虽然ASP.NET的服务器控件一直被大家所诟病,但是用户控件(ACSX)在某些场景下还是非常有用的. 在一些极特珠的情况下,我们会使用JavaScript动态的构建页面中的控件,但假设遇到了我要用JavaScript构建一个服务端控件.用户控件时,该怎么办? 我们常常说,服务端控件运行在服端器上,那么这话是什么意思呢? 服务端控件,其本质是一构建HTML语句的封装,以事先编排好的方式,生成一套HTML并通过Http协议返回给客户端.因此,我们所写的服务端控件,在响应HTTP请求时,早已不存