Javascript专题(三)c.各种轮播--上下滚动轮播(面向对象版本)
<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>Document</title>
	<style type="text/css">
		body,div,ul,li{margin: 0;padding: 0;list-style: none;}
		body{
			background: #000;
		}
		#box{
			margin: 10px auto;
			width: 492px;
			height: 172px;
			border: 8px solid #fff;
			border-radius: 5px; 
			position: relative;
		}
		#box .list{
			width: 490px;
			height: 170px;
			border: 1px solid blue;
			overflow: hidden;
			position: relative;
		}
		#box .list ul{
			position: absolute;
			top: 0;
			left: 0;
		}
		#box .list ul li{
			width: 490px;
			height: 170px;
			overflow: hidden;
		}
		#box .list-count{
			position: absolute;
			right: 0;
			bottom: 5px;
			cursor: pointer;
		}
		#box .list-count li{
			color: #fff;
			float: left;
			margin-right: 5px;
			border-radius: 5px;
			background: #f60;
			width: 20px;
			height: 20px;
			text-align: center;
			font: 12px/20px Arial;
			opacity: 0.7;
			filter: alpha(opacity=70);
		}
		#box .list-count li.current{
			opacity: 1;
			filter: alpha(opacity=100);
		}
	</style>
</head>
<body>
	<div id="box">
		<div class="list">
			<ul>
				<li><img src="../image/landscape_map/055.jpg" width="490" height="170"></li>
				<li><img src="../image/landscape_map/037.jpg" width="490" height="170"></li>
				<li><img src="../image/landscape_map/039.jpg" width="490" height="170"></li>
				<li><img src="../image/landscape_map/032.jpg" width="490" height="170"></li>
				<li><img src="../image/landscape_map/038.jpg" width="490" height="170"></li>
			</ul>
		</div>
	</div>
</body>
<script type="text/javascript">
	//获取ID
	var $=function(id){return typeof id==="string"?document.getElementById(id):id}
	//获取tagName
	var $$=function(tagName,oParent){return (oParent||document).getElementsByTagName(tagName)}
	//自动轮播对象
	var obj_Auto=function(id){this.init(id)};
	obj_Auto.prototype={
		init:function(id){
			var oThis=this;
			this.oBox=$(id);
			this.oUl=$$("ul",this.oBox)[0];
			this.aImg=$$("img",this.oBox);
			this.createBtn();
			this.aBtn=$$("li",this.oCount);
			this.iNow=0;
			this.start_timer=null;
			this.auto_timer=null;
			for(var i=0;i<this.aBtn.length;i++){
				this.aBtn[i].index=i;
				this.aBtn[i].onmouseover=function(){
					oThis.iNow=this.index;
					//去除自动播放时的bug
					//另外这两句话位置不能错了,否则就是上一次的Show了
					oThis.Show();
				}
			}
			this.oBox.onmouseout=function(){
				oThis.Auto();
			}
			this.oBox.onmouseover=function(){
				clearInterval(oThis.auto_timer);
			}
		},
		createBtn:function(){
			//碎片传递,用于提升效率,将所有新增先添加到碎片中,防止多次渲染导致的流畅°下降问题。
			//另外一种方法:可以先扔进数组里,主要多次for循环的创建
			this.oCount=document.createElement("ul");
			this.oFrag=document.createDocumentFragment();
			this.oCount.className="list-count";
			for(var i=0;i<this.aImg.length;i++){
				var oLi=document.createElement("li");
				oLi.innerHTML=i+1;
				this.oFrag.appendChild(oLi);
			}
			this.oCount.appendChild(this.oFrag);
			this.oBox.appendChild(this.oCount);
		},
		Show:function(){
			for(var i=0;i<this.aBtn.length;i++)this.aBtn[i].className="";
			this.aBtn[this.iNow].className="current";
			this.Move(-this.iNow*this.aImg[0].offsetHeight);
		},
		Move:function(distance){
			var oThis=this;
			clearInterval(this.start_timer);
			this.start_timer=setInterval(function(){
				var speed=(distance-oThis.oUl.offsetTop)/10;
				speed=speed>0?Math.ceil(speed):Math.floor(speed);
				//若是不总是向上取整,会永远到不了
				oThis.oUl.offsetTop==distance?clearInterval(oThis.start_timer)
				:oThis.oUl.style.top=oThis.oUl.offsetTop+speed+"px";
			},30)
		},
		Auto:function(){
			var oThis=this;
			clearInterval(this.suto_timer);
			this.auto_timer= setInterval(function(){
				oThis.iNow<oThis.aImg.length-1? oThis.iNow++:(oThis.iNow=0);
				oThis.Show();
			},2000);
		}
	}
	new obj_Auto("box");//在没有创建之前不可以直接
	var x=new obj_Auto("box");
</script>
</html>
Javascript专题(三)c.各种轮播--上下滚动轮播(面向对象版本)的更多相关文章
- Javascript专题(三)b.各种轮播和细节分析--上下滚动轮播
		这一次,我们用原生JS实现上下滚动方式的轮播.顺带学习一下用JS来创建HTML元素. 上一次写的轮播是淡入淡出效果的,相对来说其实是比较简单的. github源码: 上下轮播源码-github A. ... 
- 天猫京东app中常见的上下滚动轮播效果如何实现?
		前段时间,公司安排我制作一个上下滚动轮播效果,类似于我们在天猫京东app中常见的这样: 哇kao!这个我完全不会呀??? 幸好,前几天一个朋友在朋友圈分享了一篇推文.瞬间引领我走出了迷茫,这个教程特别 ... 
- js 手动轮播和自动轮播
		$(function(){ //默认值 $("#carousel1").css("background-color","#FFF"); // ... 
- 原生JS轮播-各种效果的极简实现(二)面向对象版本的实现和优化
		之前写了一篇原生JS轮播,不过是非面向对象的,并且也没有添加上自动轮播.这里来写一下如何优化和进阶. 这里简单地介绍一下之前的代码,这是html结构 <body> <div clas ... 
- 原生js手动轮播图
		手动轮播图,为轮播图中的一种,轮播图主要有无缝轮播,手动轮播,延迟轮播,切换轮播等等... 轮播图主要用于展现图片,新出商品,词条,又能美观网页.給网页中增加动态效果. 手动轮播,是小编认为最简单的一 ... 
- javascript效果:手风琴、轮播图、图片滑动
		最近都没有更,就来几个效果充实一下. 都没有进行美化这步. 手风琴: 纯css: <!DOCTYPE html> <html lang="en"> < ... 
- Javascript和jQuery WordPress 图片轮播插件, 内容滚动插件,前后切换幻灯片形式显示
		用于在有限的网页空间内展示一组产品图片或者照片,同时还有非常吸引人的动画效果.本文向大家推荐12款实用的 jQuery 图片轮播效果插件,帮助你在你的项目中加入一些效果精美的图片轮播效果,希望这些插件 ... 
- 使用JavaScript制作一个好看的轮播图
		目录 使用JavaScript制作出好看的轮播图效果 准备材料 1.图片若干张(包括轮播图和按钮的图片) 2.将按钮的图片应用到按钮上的CSS样式文件 3.实现轮播和点击跳转的JavaScript代码 ... 
- 使用javascript,jquery实现的图片轮播功能
		使用javascript,jquery实现的图片轮播功能本功能采用最基础的javascript和一些简单的jquery技术实现,易理解,以修改使用,代码简易,适合刚开始接触到网站开发的朋友们参考.可以 ... 
随机推荐
- [原]NYOJ-开灯问题-77
			大学生程序代写 //http://acm.nyist.net/JudgeOnline/problem.php?pid=77 /*题目77题目信息运行结果本题排行讨论区开灯问题 时间限制:3000 ms ... 
- Mybatis学习--XML映射配置文件
			学习笔记,选自Mybatis官方中文文档:http://www.mybatis.org/mybatis-3/zh/configuration.html MyBatis 的配置文件包含了影响 MyBat ... 
- 2017-2018-1 20179215《Linux内核原理与分析》第九周作业
			实验:理解进程调度时机跟踪分析进程调度与进程切换的过程 一.实验要求 (1)理解Linux系统中进程调度的时机,可以在内核代码中搜索schedule()函数,看都是哪里调用了schedule(),判 ... 
- C++中getline的用法
			在看紫皮书的时候看到getline,然后查了查具体用法,记录下来. #include"iostream" #include"string" using name ... 
- C#中怎么解析JSON数据,并获取到其中的值?
			[1]首先我们根据创建一个json字符转 string json = @"[{'phantom':true,'id':'20130717001','data':{'MID':1019,'Na ... 
- spark提交模式
			spark基本的提交语句: ./bin/spark-submit \ --class <main-class> \ --master <master-url> \ --depl ... 
- Mybaits整合Spring自动扫描 接口,Mybaits配置文件.xml文件和Dao实体类
			1.转自:https://blog.csdn.net/u013802160/article/details/51815077 <?xml version="1.0" enco ... 
- python 基础 列表 字符串转换
			1. 字符串转列表 str1 = "hi hello world" print(str1.split(" "))输出:['hi', 'hello', 'worl ... 
- 特征降维之SVD分解
			奇异值分解.特征值分解是一个提取矩阵特征很不错的方法,但是它只是对方阵而言的,在现实的世界中,我们看到的大部分矩阵都不是方阵,比如说有N个学生,每个学生有M科成绩,这样形成的一个N * M的矩阵就不可 ... 
- Oracal主键 唯一报错
			ORA-00001: 违反唯一约束条件 --解决方法 2017年07月27日 12:04:11 阅读数:11853 1.错误 Caused by: java.sql.BatchUpdateExcept ... 
