jQuery实现大图轮播


Posted in Javascript onFebruary 13, 2017

css样式:

*{
 margin: 0;
 padding: 0;
}
ul{
 list-style:none;
}
.slideShow{
 width: 620px;
 height: 700px; /*其实就是图片的高度*/
 border: 1px #eeeeee solid;
 margin: 100px auto;
 position: relative;
 overflow: hidden; /*此处需要将溢出框架的图片部分隐藏*/
}
.slideShow ul{
 width: 2500px;
 position: relative; /*此处需注意relative : 对象不可层叠,但将依据left,right,top,bottom等属性在正常文档流中偏移位置,如果没有这个属性,图片将不可左右移动*/
}
.slideShow ul li{
 float: left; /*让四张图片左浮动,形成并排的横着布局,方便点击按钮时的左移动*/
 width: 620px;
}
.slideShow .showNav{ /*用绝对定位给数字按钮进行布局*/
 position: absolute;
 right: 10px;
 bottom: 5px;
 text-align:center;
 font-size: 12px; 
 line-height: 20px;
}
.slideShow .showNav span{
 cursor: pointer;
 display: block;
 float: left;
 width: 20px;
 height: 20px;
 background: #ff5a28;
 margin-left: 2px;
 color: #fff;
}
.slideShow .showNav .active{
 background: #b63e1a;
}

js代码规范:

<script src="../../../jQuery/js/jquery-2.1.4.js"></script> <script type="text/javascript">
$(document).ready(function(){ 
var slideShow=$(".slideShow"),  //获取最外层框架的名称 
ul=slideShow.find("ul"), 
showNumber=slideShow.find(".showNav span"),   //获取按钮 
oneWidth=slideShow.find("ul li").eq(0).width();   //获取每个图片的宽度 
var timer=null;   //定时器返回值,主要用于关闭定时器 
var iNow=0;   //iNow为正在展示的图片索引值,当用户打开网页时首先显示第一张图,即索引值为0 
showNumber.on("click",function(){    //为每个按钮绑定一个点击事件  
$(this).addClass("active").siblings().removeClass("active");  //按钮点击时为这个按钮添加高亮状态,并且将其他按钮高亮状态去掉 
var index=$(this).index();    //获取哪个按钮被点击,也就是找到被点击按钮的索引值 
iNow=index; 
ul.animate({ "left":-oneWidth*iNow,  //注意此处用到left属性,所以ul的样式里面需要设置position: relative; 让ul左移N个图片大小的宽度,N根据被点击的按钮索引值iNOWx确定 
 }) 
 }); 
 function autoplay(){ 
timer=setInterval(function(){   //打开定时器 
iNow++;     //让图片的索引值次序加1,这样就可以实现顺序轮播图片 
 if(iNow>showNumber.length-1){   //当到达最后一张图的时候,让iNow赋值为第一张图的索引值,轮播效果跳转到第一张图重新开始 
iNow=0; } 
showNumber.eq(iNow).trigger("click");   //模拟触发数字按钮的click 

},2000);     //2000为轮播的时间
} 
 autoplay(); 
 slideShow.hover( function(){clearInterval(timer);},autoplay); 另外注意setInterval的用法比较关键。
})
</script>

主体代码:

<body>
 <div class="slideShow">
 <!--图片布局开始-->
 <ul>
 <li><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><img src="images/view/111.jpg"/></a></li>
 <li><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><img src="images/view/112.jpg" /></a></li>
 <li><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><img src="images/view/113.jpg" /></a></li>
 <li><a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" ><img src="images/view/114.jpg" /></a></li>
 </ul>
 <!--图片布局结束-->
 <!--按钮布局开始-->
 <div class="showNav">
 <span class="active">1</span>
 <span>2</span>
 <span>3</span>
 <span>4</span>
 </div>
 <!--按钮布局结束-->
 </div>
</body>

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
基于prototype的validation.js发布2.3.4新版本,让你彻底脱离表单验证的烦恼
Dec 06 Javascript
Windows 系统下安装和部署Egret的开发环境
Jul 31 Javascript
javascript实现节点(div)名称编辑
Dec 17 Javascript
JavaScript SHA512&amp;SHA256加密算法详解
Aug 11 Javascript
易被忽视的js事件问题总结
May 14 Javascript
jquery滚动条插件(可以自定义)
Dec 11 Javascript
angular+ionic 的app上拉加载更新数据实现方法
Jan 16 Javascript
canvas知识总结
Jan 25 Javascript
jQuery使用ajax_动力节点Java学院整理
Jul 05 jQuery
vue如何判断dom的class
Apr 26 Javascript
javascript设计模式 ? 组合模式原理与应用实例分析
Apr 14 Javascript
(开源)微信小程序+mqtt,esp8266温湿度读取
Apr 02 Javascript
使用ionic在首页新闻中应用到的跑马灯效果的实现方法
Feb 13 #Javascript
你真的了解BOM中的history对象吗
Feb 13 #Javascript
微信小程序-获得用户输入内容
Feb 13 #Javascript
js实现textarea限制输入字数
Feb 13 #Javascript
Canvas实现动态的雪花效果
Feb 13 #Javascript
JavaScript中从setTimeout与setInterval到AJAX异步
Feb 13 #Javascript
Bootstrap选项卡学习笔记分享
Feb 13 #Javascript
You might like
让你的WINDOWS同时支持MYSQL4,MYSQL4.1,MYSQL5X
2006/12/06 PHP
PHP define函数的使用说明
2008/08/27 PHP
php url地址栏传中文乱码解决方法集合
2010/06/25 PHP
php 运算符与表达式详细介绍
2016/11/30 PHP
关于使用runtimeStyle属性问题讨论文章
2007/03/08 Javascript
json 实例详细说明教程
2009/10/31 Javascript
Exitjs获取DataView中图片文件名
2009/11/26 Javascript
IE与FireFox中的childNodes区别
2011/10/20 Javascript
自己写了一个展开和收起的多更能型的js效果
2013/03/05 Javascript
jQuery中bind,live,delegate与one方法的用法及区别解析
2013/12/30 Javascript
jquery默认校验规则整理
2014/03/24 Javascript
使用vue编写一个点击数字计时小游戏
2016/08/31 Javascript
vue-cli基础配置及webpack配置修改的完整步骤
2019/10/20 Javascript
JS桶排序的简单理解与实现方法示例
2019/11/25 Javascript
详解ES6新增字符串扩张方法includes()、startsWith()、endsWith()
2020/05/12 Javascript
利用python获得时间的实例说明
2013/03/25 Python
python从sqlite读取并显示数据的方法
2015/05/08 Python
Python实现可自定义大小的截屏功能
2018/01/20 Python
Python使用一行代码获取上个月是几月
2018/08/30 Python
在Pycharm中修改文件默认打开方式的方法
2019/01/17 Python
基于opencv实现简单画板功能
2020/08/02 Python
Python3基于plotly模块保存图片表格
2020/08/03 Python
Python读写csv文件流程及异常解决
2020/10/20 Python
使用HTML5和CSS3表单验证功能
2017/05/05 HTML / CSS
解决Firefox下不支持outerHTML问题代码分享
2014/06/04 HTML / CSS
澳大利亚吉他在线:Artist Guitars
2017/03/30 全球购物
巴西最大的巴士票务门户:Quero Passagem
2020/11/21 全球购物
Fanatics官网:运动服装、球衣、运动装备
2020/10/12 全球购物
大唐电信科技股份有限公司java工程师面试经历
2016/12/09 面试题
司机岗位职责
2013/11/15 职场文书
会计专业自荐信范文
2013/12/02 职场文书
师范生自我鉴定
2014/03/20 职场文书
青年文明号服务承诺
2014/03/31 职场文书
电子商务专业应届毕业生求职信
2014/06/21 职场文书
计划生育证明书写要求
2014/09/17 职场文书
flex弹性布局详解
2022/03/20 HTML / CSS