本文实例为大家分享了js实现轮播图的具体代码,供大家参考,具体内容如下

1、构造函数
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style type='text/css'>
*{ margin:0; padding:0;}
#wrap{
width:500px;
height:360px;
margin:100px auto;
position:relative;
}
#pic{
width:500px;
height:360px;
position:relative;
}
#pic img{
width: 100%;
height: 100%;
position:absolute;
top:0;
left:0;
display:none;
}
#tab{
width:105px;
height:10px;
position:absolute;
bottom:10px;
left:50%;
margin-left:-50px;
}
#tab ul li{
width:10px;
height:10px;
margin:0 5px;
background:#bbb;
border-radius:100%;
cursor:pointer;
list-style:none;
float:left;
}
#tab ul li.on{ background:#f60;}
#btn div{
width:40px;
height:40px;
position:absolute;
top:50%;
margin-top:-20px;
color:#fff;
background:#999;
background:rgba(0,0,0,.5);
font-size:20px;
font-weight:bold;
font-family:'Microsoft yahei';
line-height:40px;
text-align:center;
cursor:pointer;
}
#btn div#left{ left:0;}
#btn div#right{ right:0;}
</style>
</head>
<body>
<div id="wrap">
<div id="pic">
<img src="img/1.jpg" alt="" />
<img src="img/2.jpg" alt="" />
<img src="img/3.jpg" alt="" />
<img src="img/4.jpg" alt="" />
</div>
<div id="tab">
<ul>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
</div>
<div id="btn">
<div id='left'><</div>
<div id='right'>></div>
</div>
</div>
<script>
var oWrap=document.getElementById('wrap')
var picImg=document.getElementById('pic').getElementsByTagName('img');
var tabLi=document.getElementById('tab').getElementsByTagName('li');
var btnDiv=document.getElementById('btn').getElementsByTagName('div');
var index=0;
var timer=null;//设置一个timer变量,让他的值为空
//初始化
picImg[0].style.display='block';
tabLi[0].className='on';
for(var i=0;i<tabLi.length;i++){
tabLi[i].index=i;
tabLi[i].onclick=function(){
//不然要for循环清空
/* for(var i=0;i<tabLi.length;i++){
picImg[i].style.display='none';
tabLi[i].className='';
}*/
picImg[index].style.display='none'; //每个li都有index自定义属性
tabLi[index].className='';
index=this.index;
picImg[index].style.display='block';
tabLi[index].className='on';
}
};
for(var i=0;i<btnDiv.length;i++){
btnDiv[i].index=i;
btnDiv[i].onselectstart=function(){ //禁止选择
return false;
}
btnDiv[i].onclick=function(){
picImg[index].style.display='none'; //每个li都有index自定义属性
tabLi[index].className='';
//index=this.index;
if(this.index){
index++; //进来就加1,index就相当1%4 2%4 3%4 4%4
//if(index>tabLi.length){index=0}
//index=index%arrUrl.length; 自己取模自己等于0 alert(3%3) == 0
index%=tabLi.length;//相当于当大于tabLi.length就等于0
}else{
index--;
if(index<0)index=tabLi.length-1;
}
picImg[index].style.display='block';
tabLi[index].className='on';
}
};
auto();
oWrap.onmouseover=function(){
clearInterval(timer)
}
oWrap.onmouseleave=function(){
auto();
}
function auto(){
timer=setInterval(function(){ //一般都是向*播,index++
picImg[index].style.display='none';
tabLi[index].className='';
index++;
index%=tabLi.length;
picImg[index].style.display='block';
tabLi[index].className='on';
},2000)
};
</script>
</body>
</html>
2、面向对象
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<style type='text/css'>
*{ margin:0; padding:0;}
#wrap{
width:500px;
height:360px;
margin:100px auto;
position:relative;
}
#pic{
width:500px;
height:360px;
position:relative;
}
#pic img{
width: 100%;
height: 100%;
position:absolute;
top:0;
left:0;
display:none;
}
#tab{
width:105px;
height:10px;
position:absolute;
bottom:10px;
left:50%;
margin-left:-50px;
}
#tab ul li{
width:10px;
height:10px;
margin:0 5px;
background:#bbb;
border-radius:100%;
cursor:pointer;
list-style:none;
float:left;
}
#tab ul li.on{ background:#f60;}
#btn div{
width:40px;
height:40px;
position:absolute;
top:50%;
margin-top:-20px;
color:#fff;
background:#999;
background:rgba(0,0,0,.5);
font-size:20px;
font-weight:bold;
font-family:'Microsoft yahei';
line-height:40px;
text-align:center;
cursor:pointer;
}
#btn div#left{ left:0;}
#btn div#right{ right:0;}
</style>
</head>
<body>
<div id="wrap">
<div id="pic">
<img src="img/1.jpg" alt="" />
<img src="img/2.jpg" alt="" />
<img src="img/3.jpg" alt="" />
<img src="img/4.jpg" alt="" />
</div>
<div id="tab">
<ul>
<li></li>
<li></li>
<li></li>
<li></li>
</ul>
</div>
<div id="btn">
<div id='left'><</div>
<div id='right'>></div>
</div>
</div>
<script>
var oWrap=document.getElementById('wrap')
var picImg=document.getElementById('pic').getElementsByTagName('img');
var tabLi=document.getElementById('tab').getElementsByTagName('li');
var btnDiv=document.getElementById('btn').getElementsByTagName('div');
function Banner(oWrap,picImg,tabLi,btnDiv){
this.wrap=oWrap
this.list=picImg
this.tab=tabLi
this.btn=btnDiv
this.index=0; //这些都必须是私有的,不然两个banner会一样
this.timer=null;
this.length=this.tab.length;
// this.init();//下面创建好,要在这里执行
}
//初始化分类
Banner.prototype.init=function(){ //先把下面的分类
var This=this; //var 一个This变量把this存起来
this.list[0].style.display='block';
this.tab[0].className='on';
for(var i=0;i<this.length;i++){
this.tab[i].index=i;
this.tab[i].onclick=function(){
//this.list[index].style.display='none'; 这里的this指向tab的this
This.list[This.index].style.display='none';
This.tab[This.index].className='';
//index=this.index;
This.index=this.index;
This.list[This.index].style.display='block';
//This.tab[This.index].className='on';
this.className='on';
}
};
for(var i=0;i<this.btn.length;i++){
this.btn[i].index=i;
this.btn[i].onselectstart=function(){
return false;
}
this.btn[i].onclick=function(){
This.list[This.index].style.display='none';
This.tab[This.index].className='';
if(this.index){
This.index++;
This.index%=This.length;
}else{
This.index--;
if(index<0)This.index=This.length-1;
}
This.list[This.index].style.display='block';
This.tab[This.index].className='on';
}
}
this.auto();
this.clear();
};
Banner.prototype.auto=function(){
var This=this;
This.timer=setInterval(function(){ //一般都是向*播,index++
This.list[This.index].style.display='none';
This.tab[This.index].className='';
This.index++;
This.index%=This.length;
This.list[This.index].style.display='block';
This.tab[This.index].className='on';
},2000)
};
Banner.prototype.clear=function(){
var This=this;
this.wrap.onmouseover=function(){
clearInterval(This.timer)
}
this.wrap.onmouseleave=function(){
This.auto();
}
};
var banner1=new Banner(oWrap,picImg,tabLi,btnDiv);
banner1.init();
/*
* init()
* function init(){
for(var i=0;i<tabLi.length;i++){
tabLi[i].index=i;
tabLi[i].onclick=function(){
picImg[index].style.display='none';
tabLi[index].className='';
index=this.index;
picImg[index].style.display='block';
tabLi[index].className='on';
}
};
}
for(var i=0;i<btnDiv.length;i++){
btnDiv[i].index=i;
btnDiv[i].onselectstart=function(){
return false;
}
btnDiv[i].onclick=function(){
picImg[index].style.display='none';
tabLi[index].className='';
if(this.index){
index++;
index%=tabLi.length;
}else{
index--;
if(index<0)index=tabLi.length-1;
}
picImg[index].style.display='block';
tabLi[index].className='on';
}
};
auto();
oWrap.onmouseover=function(){
clearInterval(timer)
}
oWrap.onmouseleave=function(){
auto();
}
function auto(){
timer=setInterval(function(){ //一般都是向*播,index++
picImg[index].style.display='none';
tabLi[index].className='';
index++;
index%=tabLi.length;
picImg[index].style.display='block';
tabLi[index].className='on';
},2000)
};
*/
</script>
</body>
</html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
# js
# 轮播图
# js核心基础之构造函数constructor用法实例分析
# 深入浅析js原型链和vue构造函数
# 详解Javascript 中的 class、构造函数、工厂函数
# 详解JS构造函数中this和return
# Javascript中获取对象的原型对象的方法小结
# 深入理解javascript构造函数和原型对象
# 一文秒懂JavaScript构造函数、实例、原型对象以及原型链
# 都是
# 都有
# 自定义
# 要在
# 先把
# 大家分享
# 就等于
# 具体内容
# 值为
# 大家多多
# 面向对象
# 清空
# 都必须
# tab
# display
# left
# top
# bottom
# pic
# relative
相关文章:
高性价比服务器租赁——企业级配置与24小时运维服务
如何获取免费开源的自助建站系统源码?
香港服务器选型指南:免备案配置与高效建站方案解析
如何在建站宝盒中设置产品搜索功能?
网站制作多少钱一个,建一个论坛网站大约需要多少钱?
实惠建站价格推荐:2025年高性价比自助建站套餐解析
建站主机选哪种环境更利于SEO优化?
如何快速查询网站的真实建站时间?
娃派WAP自助建站:免费模板+移动优化,快速打造专业网站
建站之星伪静态规则如何正确配置?
建站之星安装提示数据库无法连接如何解决?
如何通过商城自助建站源码实现零基础高效建站?
javascript中对象的定义、使用以及对象和原型链操作小结
如何在Golang中使用encoding/gob序列化对象_存储和传输数据
常州企业网站制作公司,全国继续教育网怎么登录?
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
微信h5制作网站有哪些,免费微信H5页面制作工具?
免费制作小说封面的网站有哪些,怎么接网站批量的封面单?
如何在宝塔面板中修改默认建站目录?
建站主机如何选?性能与价格怎样平衡?
猪八戒网站制作视频,开发一个猪八戒网站,大约需要多少?或者自己请程序员,需要什么程序员,多少程序员能完成?
建站主机与服务器功能差异如何区分?
免费制作海报的网站,哪位做平面的朋友告诉我用什么软件做海报比较好?ps还是cd还是ai这几个软件我都会些我是做网页的?
linux top下的 minerd 木马清除方法
西安市网站制作公司,哪个相亲网站比较好?西安比较好的相亲网站?
建站上传速度慢?如何优化加速网站加载效率?
制作网站的软件下载免费,今日头条开宝箱老是需要下载怎么回事?
南阳网站制作公司推荐,小学电子版试卷去哪里找资源好?
建站VPS配置与SEO优化指南:关键词排名提升策略
建站之星IIS配置教程:代码生成技巧与站点搭建指南
C++ static_cast和dynamic_cast区别_C++静态转换与动态类型安全转换
制作电商网页,电商供应链怎么做?
济南专业网站制作公司,济南信息工程学校怎么样?
javascript基本数据类型及类型检测常用方法小结
如何基于云服务器快速搭建网站及云盘系统?
高防服务器租用指南:配置选择与快速部署攻略
在线教育网站制作平台,山西立德教育官网?
青岛网站设计制作公司,查询青岛招聘信息的网站有哪些?
制作销售网站教学视频,销售网站有哪些?
购物网站制作公司有哪些,哪个购物网站比较好?
表情包在线制作网站免费,表情包怎么弄?
Android自定义控件实现温度旋转按钮效果
网站代码制作软件有哪些,如何生成自己网站的代码?
C#怎么创建控制台应用 C# Console App项目创建方法
东莞市网站制作公司有哪些,东莞找工作用什么网站好?
建站之星各版本价格是多少?
如何选择美橙互联多站合一建站方案?
Swift中swift中的switch 语句
如何用PHP工具快速搭建高效网站?
,购物网站怎么盈利呢?
*请认真填写需求信息,我们会在24小时内与您取得联系。