下面来看看最终做的手动点击轮播效果:
一、原理说明
(1)首先是轮播图的架构,我采用了一个最外边的大div包住两个小div,一个小div里面放四张图片,另一个小div里面放四个数字按钮
(2)对最外边的大div设置的宽度为图片的宽度,超出大div宽度的都需要隐藏,但是对于盛放图片的小div设置宽度为2000px,大一点方便四张图左浮动布局
(3)当数字按钮点击时,获取按钮的索引值,这样就可以知道每张图片左移多少宽度
从上面的图可以看出,四张图片是浮动起来横着的布局,当数字按钮被点击时,图片就要按照数字按钮的索引值引动n个图片的宽度到达父框架里面展示,因为父框架外面的图片都会被隐藏掉~~~~~如果你还看不懂原理的话,我只能吐血了~~~~
二、下面来看主体程序
轮播图①(手动点击轮播) 1 2 3 4
上面布局我已经在原理中说明了,感兴趣的自己看原理~~~~
三、css样式
*{ margin: 0; padding: 0;}ul{ list-style: none;}.slideshow{ width: 346px; height: 210px; /*其实就是图片的高度*/ border: 1px #eeeeee solid; margin: 100px auto; position: relative; overflow: hidden; /*此处需要将溢出框架的图片部分隐藏*/}.slideshow ul{ width: 2000px; position: relative; /*此处需注意relative : 对象不可层叠,但将依据left,right,top,bottom等属性在正常文档流中偏移位置,如果没有这个属性,图片将不可左右移动*/}.slideshow ul li{ float: left; /*让四张图片左浮动,形成并排的横着布局,方便点击按钮时的左移动*/ width: 346px;}.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;}
上面样式我已经备注出来很重要的地方了,相信有基础的很容易看懂,刚开始我在.slideshow ul样式里面忘了写position: relative;导致后面的jquery程序图片一直无法移动,耽误了很长时间才找出这个错误,希望大家可以注意这个地方~~~~~~~
四、jquery程序
$(document).ready(function(){ var slideshow=$(.slideshow), //获取最外层框架的名称 ul=slideshow.find(ul), shownumber=slideshow.find(.shownav span),//获取按钮 onewidth=slideshow.find(ul li).eq(0).width(); //获取每个图片的宽度 shownumber.on(click,function(){ //为每个按钮绑定一个点击事件 $(this).addclass(active).siblings().removeclass(active); //按钮被点击时为这个按钮添加高亮状态,并且将其他按钮高亮状态去掉 var index=$(this).index(); //获取哪个按钮被点击,也就是找到被点击按钮的索引值 ul.animate({ left:-onewidth*index, //注意此处用到left属性,所以ul的样式里面需要设置position: relative; 让ul左移n个图片大小的宽度,n根据被点击的按钮索引值index确定 }) })})
是不是觉得很简单,也是几句话就搞定了手动点击的轮播效果,上面程序需要注意的是left属性是左移动,所以为负值~~~~~~~
下次文章就为大家分享自动轮播特效,希望大家不要错过。