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 解疑
Nov 11 Javascript
javascript的数据类型、字面量、变量介绍
May 23 Javascript
提升页面加载速度的插件InstantClick
Sep 12 Javascript
微信小程序使用radio显示单选项功能【附源码下载】
Dec 11 Javascript
js中bool值的转换及“&amp;&amp;”、“||”、 “!!”详解
Dec 21 Javascript
JS实现标签滚动切换效果
Dec 25 Javascript
浅谈开发eslint规则
Oct 01 Javascript
Vue路由前后端设计总结
Aug 06 Javascript
jQuery实现简易聊天框
Feb 08 jQuery
jQuery 淡入/淡出效果函数用法分析
May 19 jQuery
Openlayers测量距离与面积的实现方法
Sep 25 Javascript
如何理解Vue简单状态管理之store模式
May 15 Vue.js
使用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
php开发环境配置记录
2011/01/14 PHP
PHP学习笔记之一
2011/01/17 PHP
关于file_get_contents返回为空或函数不可用的解决方案
2013/06/24 PHP
PHP中文字符串截断无乱码解决方法
2016/10/10 PHP
详谈PHP面向对象中常用的关键字和魔术方法
2017/02/04 PHP
php删除二维数组中的重复值方法
2018/03/12 PHP
Swoole扩展的6种模式深入详解
2021/03/04 PHP
HTML Color Picker(js拾色器效果)
2013/08/27 Javascript
javascript中关于&amp;&amp; 和 || 表达式的小技巧分享
2015/04/10 Javascript
JS获取IE版本号与HTML设置IE文档模式的方法
2016/10/09 Javascript
Bootstrap Table使用心得总结
2016/11/29 Javascript
深入理解nodejs中Express的中间件
2017/05/19 NodeJs
JS点击缩略图整屏居中放大图片效果
2017/07/04 Javascript
利用JS制作万年历的方法
2017/08/16 Javascript
使用node.js对音视频文件加密的实例代码
2017/08/30 Javascript
Vue实现本地购物车功能
2018/12/05 Javascript
vue 更改连接后台的api示例
2019/11/11 Javascript
JavaScript数组及常见操作方法小结
2019/11/13 Javascript
vue+elementui通用弹窗的实现(新增+编辑)
2021/01/07 Vue.js
Python正则表达式匹配ip地址实例
2014/10/09 Python
python opencv旋转图像(保持图像不被裁减)
2018/07/26 Python
Python中断多重循环的几种方式详解
2020/02/10 Python
Html5页面点击遮罩层背景关闭遮罩层
2020/11/30 HTML / CSS
打造经典复古风格的品牌:Alice + Olivia(爱丽丝+奥利维亚)
2016/09/07 全球购物
DJI大疆无人机官方商城:全球领先的无人飞行器研发和生产商
2016/12/21 全球购物
土耳其时尚购物网站:Morhipo
2017/09/04 全球购物
日本酒店、民宿、温泉旅馆、当地旅行团中文预订:e路东瀛
2019/12/09 全球购物
杭州SQL浙江浙大网新恩普软件有限公司
2013/07/27 面试题
事业单位分类改革实施方案
2014/03/21 职场文书
人力资源本科毕业生求职信
2014/06/04 职场文书
总经理任命书范本
2014/06/05 职场文书
个性发展自我评价2015
2015/03/09 职场文书
无工作证明怎么写
2015/06/15 职场文书
学生会副主席竞选稿
2015/11/19 职场文书
建房合同协议书
2016/03/21 职场文书
python爬取豆瓣电影TOP250数据
2021/05/23 Python