搞了很长时间才弄清楚图片轮播效果的原理,理解各个事件发生的原因,浪费了这么长的时间,只怪自己的知识太过于薄弱。现将代码写下,供大家参看,如有不妥之处还望指出,大家一起学习。

功能:

1、点击左右两边的按钮,可以让图片进行左右滚动。

2、鼠标点击下方的一排按钮,可切换至想要的那张图片。

3、鼠标经过下方的一排按钮上时,可对图片进行小图预览。

4、当没有鼠标事件时,图片可进行自动播放。

5、当鼠标停留在整个区域上时,图片停止自动播放,当鼠标移出时,继续自动播放。

效果:

代码如下:

 <!DOCTYPE HTML>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<meta http-equiv="X-UA-Compatible" content="IE=10,chrome=1" />
<title>图片轮换效果</title>
<style>
body,div,ul,li,a,img,span{padding:0;margin:0;}
img{border:0;vertical-align:middle;}
li{list-style:none;}
body{width:100%;height:100px;background:url(img/bg.jpg) no-repeat;font-family:'微软雅黑';}
.wrap{width:742px;height:462px;margin:10% auto 60px;position:relative;}
.tit{height:50px;line-height:50px;padding-left:10px;margin-bottom:12px;font-size:30px;color:#fff;}
p{width:742px;height:462px;position:absolute;padding:0;margin:0;}
#img{width:686px;height:390px;margin:28px 0 0 28px;}
.wrap a{width:30px;height:60px;line-height:60px;text-align:center;top:208px;position:absolute;display:block;opacity:0.5;filter: progid:DXImageTransform.Microsoft.Alpha(opacity=50);}
.wrap a:hover{opacity:1;filter: progid:DXImageTransform.Microsoft.Alpha(opacity=100);}
#prev{left:2px;}
#next{right:2px;}
.btdiv{width:686px;height:50px;line-height:50px;position:absolute;bottom:0;left:37px;}
.pic_intro{width:400px;height:50px;line-height:50px;color:#000;font-size:16px;float:left;padding-left:10px;}
#ul1{height:10px;padding-top:20px;float:right;padding-right:24px;}
#ul1 li{width:14px;height:11px;float:left;margin-left:14px;background:url(img/dot_11.png) no-repeat;position:relative;}
#ul1 .active{background:url(img/dot_22.png) no-repeat;}
#ul1 span{width:76px;height:69px;display:none;position:absolute;top:-74px;left:-34px;background:url(img/dot_3.png) no-repeat center bottom;}
#ul1 img{width:70px;height:56px;border:3px solid #fff;border-radius:5px;}
.btm{width:100%;height:60px;background:url(img/btm.png) repeat-x;position:fixed;bottom:0;}
</style>
<script>
window.onload=function(){
var oWrap=document.getElementById('wrap');
var oImg=document.getElementById('img');
var oPre=document.getElementById('prev');
var oNext=document.getElementById('next');
var oNext=document.getElementById('next');
var oTxt=document.getElementById('txt');
var oUl1=document.getElementById('ul1');
var aLi=oUl1.getElementsByTagName('li');
var arrIMG1=['img/1.jpg','img/2.jpg','img/3.jpg','img/4.jpg']
var arrTXT=['春天--等闲识得东风面,万紫千红总是春','夏天--绿树阴浓夏日长,楼台倒影入池塘','秋天--榈庭多落叶,慨然知已秋','冬天--寒风摧树木,严霜结庭兰']
var num=0;
var timer=null;
function autoPlay(){
timer=setInterval(function(){
num++;
if(num==arrIMG1.length){
num=0;
}
show();
},800);
}
autoPlay();
oWrap.onmouseover=function(){clearInterval(timer);}
oWrap.onmouseout=autoPlay;
oPre.onclick=function(){
num--;
if(num==-1){
num=arrIMG1.length-1;
}
show();
}
oNext.onclick=function(){
num++;
if(num>=arrIMG1.length){
num=0;
}
show();
}
function show(){
oImg.src=arrIMG1[num];
oTxt.innerHTML=arrTXT[num];
for(var i=0;i<aLi.length;i++){
aLi[i].className='';
}
aLi[num].className='active';
}
for(var i=0;i<aLi.length;i++){
aLi[i].index=i;
aLi[i].onclick=function(){
oImg.src=arrIMG1[this.index];
oTxt.innerHTML=arrTXT[this.index];
for(var i=0;i<aLi.length;i++){
aLi[i].className='';
}
this.className='active';
num=this.index;
}
aLi[i].onmouseover=function(){
this.getElementsByTagName('span')[0].style.display='block';
}
aLi[i].onmouseout=function(){
this.getElementsByTagName('span')[0].style.display='none';
}
} }
</script>
</head>
<body>
<div class="wrap" id="wrap">
<p><img src="img/pic_bg.png" /></p>
<img src="img/1.jpg" id='img' />
<a href="javascript:;" id="prev"><img src="img/prev.png" /></a>
<a href="javascript:;" id="next"><img src="img/next.png" /></a>
<div class="btdiv">
<div class="pic_intro" id="txt">春天--等闲识得东风面,万紫千红总是春</div>
<ul id="ul1">
<li class="active"><span><img src="img/1.jpg" /></span></li>
<li><span><img src="img/2.jpg" /></span></li>
<li><span><img src="img/3.jpg" /></span></li>
<li><span><img src="img/4.jpg" /></span></li>
</ul>
</div>
</div>
</body>
</html>

JS--图片轮播效果的更多相关文章

  1. js图片轮播效果实现代码

    首先给大家看一看js图片轮播效果,如下图 具体思路: 一.页面加载.获取整个容器.所有放数字索引的li及放图片列表的ul.定义放定时器的变量.存放当前索引的变量index 二.添加定时器,每隔2秒钟i ...

  2. js图片轮播效果常见的产品无缝轮播

    <!DOCTYPE html> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <m ...

  3. js实现淘宝首页图片轮播效果

    原文:http://ce.sysu.edu.cn/hope2008/Education/ShowArticle.asp?ArticleID=10585 <!DOCTYPE html> &l ...

  4. jQuery个性化图片轮播效果

    jQuery个性化图片轮播效果 购物产品展示:图片轮播器<效果如下所示> 思路说明: 每隔一段时间,实现图片的自动切换及选项卡选中效果,鼠标划入图片动画停止,划出或离开动画开始 两个区域: ...

  5. CSS3图片轮播效果

    原文:CSS3图片轮播效果 在网页中用到图片轮播效果,单纯的隐藏.显示,那再简单不过了,要有动画效果,如果是自己写的话(不用jquery等),可能要费点时间.css3的出现,让动画变得不再是问题,而且 ...

  6. JQ 实现轮播图(3D旋转图片轮播效果)

    轮播图效果如下: 代码: <!DOCTYPE html> <html xmlns="/www.w3.org/1999/xhtml"> <head> ...

  7. js 图片轮播简单版

    <html> <head> <meta charset="utf-8" /> <title></title> <s ...

  8. 超实用的JavaScript代码段 Item3 --图片轮播效果

    图片轮播效果 图片尺寸 统一设置成:490*170px; 一.页面加载.获取整个容器.所有放数字索引的li及放图片列表的ul.定义放定时器的变量.存放当前索引的变量index 二.添加定时器,每隔2秒 ...

  9. ios图片轮播效果

    代码地址如下:http://www.demodashi.com/demo/11959.html ImageCarousel 简单封装的图片轮播器 内存过大由于我加载的图片分辨率较高(4k) 文件目录 ...

  10. axure 动态面板实现图片轮播效果(淘宝)

    淘宝中经常可以看到店铺中的图片轮播效果,本经验将通过axure7.0实现 工具/原料   axure7.0 方法/步骤     下载需要轮播的图片   将图片引入至axure中,将引入的第一张图片转为 ...

随机推荐

  1. Linux下遍历目录及文件,更改权限

    Linux下遍历目录及文件,更改权限 引言: 我在Linux下搭建android时,将eclipse及sdk复制到/usr/下时,总会出现无法读,无法写写样的问题. 解决方案: 有两个方案: 一.将复 ...

  2. IOS调试lldb命令常用po

    lldb命令常用(备忘) 假如你准备在模拟器里面运行这个,你可以在“(lldb)”提示的后面输入下面的: (lldb) po $eax LLDB在xcode4.3或者之后的版本里面是默认的调试器.假如 ...

  3. Android Application对象必须掌握的七点

    1:Application是什么?           Application和Activity,Service一样,是android框架的一个系统组件,当android程序启动时系统会创建一个 ap ...

  4. yii console.php 报错 Property "CConsoleApplication.theme" is not defined.

    默认配置的话,是不会出现这个错误的,应该是有人为修改了 yiic.php 这个文件,本来是 $config 载入的应该是 console.php ,人为修改后载入了 main.php 这个配置文件了 ...

  5. PV和并发

    几个概念 网站流量是指网站的访问量,用来描述访问网站的用户数量以及用户所浏览的网页数量等指标,常用的统计指标包括网站的独立用户数量.总用户数量(含重复访问者).网页浏览数量.每个用户的页面浏览数量.用 ...

  6. HUD 1251 难题统计

    /* 这题倒是没啥难度 字典树可搞 但是吧 空间是个问题 开始写成这样 struct node { int next[27],sum[27]; bool over; }t[maxn]; 死活过不了 开 ...

  7. Linux命令之 文件归档管理

    1.文件相关知识 Linux怎样保存文件 数据 -这里数据就是文件的内容 元数据 -在linux系统中,所有与某个文件相关的额外信息都保存在一个叫做i-节点(inode)的节构中 文件名 -文件名保存 ...

  8. 关于webstorm(phpstorm)设置了编码格式之后还是乱码的问题

    今天在使用phpstorm的时候,页面开始是设置utf-8的,一切正常.但是,当我从一个gbk页面复制了一段代码到phpstorm里面的时候,页面预览的时候,居然打不开了,显示是乱码.接着我就把复制的 ...

  9. 12 个 CSS 高级技巧汇总

    下面这些CSS高级技巧,一般人我可不告诉他哦. 使用 :not() 在菜单上应用/取消应用边框 给body添加行高 所有一切都垂直居中 逗号分隔的列表 使用负的 nth-child 选择项目 对图标使 ...

  10. Dreamweaver管理Svn控制器内容

    一直以来很多人使用Dreamweaver来写css和xhtml.同时如果是应用于一个多人开发的项目的时候大家会使用svn或cvs来做版本控制的工作.但是可惜的是没有听说 Dreamweaver可以与版 ...