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 相关文章推荐
javascript 拖动表格行实现代码
May 05 Javascript
十个迅速提升JQuery性能让你的JQuery跑得更快
Dec 10 Javascript
jQuery中replaceWith()方法用法实例
Dec 25 Javascript
jQuery中:image选择器用法实例
Jan 03 Javascript
js中函数声明与函数表达式
Jun 03 Javascript
jquery实现红色竖向多级向右展开的导航菜单效果
Aug 31 Javascript
无需 Flash 使用 jQuery 复制文字到剪贴板
Apr 26 Javascript
深究AngularJS——ng-checked(回写:带真实案例代码)
Jun 13 Javascript
基于js中的存储键值对以及注意事项介绍
Mar 30 Javascript
原生js封装的ajax方法示例
Aug 02 Javascript
js实现图片推拉门效果代码实例
May 18 Javascript
jQuery实现点击滚动到指定元素上的方法分析
Mar 19 jQuery
使用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
星际中的相关伤害
2020/03/04 星际争霸
一个程序下载的管理程序(四)
2006/10/09 PHP
PHP 5.0对象模型深度探索之类的静态成员
2008/03/27 PHP
php学习之数据类型之间的转换介绍
2011/06/09 PHP
php中使用临时表查询数据的一个例子
2013/02/03 PHP
解析PHP可变函数的经典用法
2013/06/20 PHP
php和jquery实现地图区域数据统计展示数据示例
2014/02/12 PHP
PHP字符串比较函数strcmp()和strcasecmp()使用总结
2014/11/19 PHP
Yii实现多按钮保存与提交的方法
2014/12/03 PHP
php使用imagecopymerge()函数创建半透明水印
2018/01/25 PHP
php反序列化长度变化尾部字符串逃逸(0CTF-2016-piapiapia)
2020/02/15 PHP
JavaScript字符串String和Array操作的有趣方法
2012/12/18 Javascript
VS2008中使用JavaScript调用WebServices
2014/12/18 Javascript
JavaScript SHA1加密算法实现详细代码
2016/10/06 Javascript
vue.js 1.x与2.0中js实时监听input值的变化
2017/03/15 Javascript
jQuery插件FusionCharts绘制的2D双面积图效果示例【附demo源码】
2017/04/11 jQuery
vue的过滤器filter实例详解
2018/09/17 Javascript
微信小程序如何获取地址
2019/12/24 Javascript
python中sys.argv参数用法实例分析
2015/05/20 Python
深入浅析Python传值与传址
2018/07/10 Python
python如何实现一个刷网页小程序
2018/11/27 Python
详解Python数据可视化编程 - 词云生成并保存(jieba+WordCloud)
2019/03/26 Python
在Tensorflow中实现梯度下降法更新参数值
2020/01/23 Python
一套C++笔试题面试题
2012/06/06 面试题
一道SQL存储过程面试题
2016/10/07 面试题
应届专科生个人的自我评价
2014/01/05 职场文书
大学生村官工作感言
2014/01/10 职场文书
小学一年级评语大全
2014/04/22 职场文书
公司员工活动策划方案
2014/08/20 职场文书
办公室文员工作自我鉴定
2014/09/19 职场文书
涪陵白鹤梁导游词
2015/02/09 职场文书
2015年业务员工作总结范文
2015/04/07 职场文书
2019年教师入党申请书
2019/06/27 职场文书
sentinel支持的redis高可用集群配置详解
2022/04/01 Redis
vue代码分块和懒加载非必要资源文件
2022/04/11 Vue.js
《金肉人》米特&《航海王》阿鹤声优松岛实因胰脏癌去世 享寿81岁
2022/04/13 日漫