用jquery操作dom确实很方便,并且jquery提供了非常人性化的api应付我们的各种需求,大大简化了js的代码。
制作原理:
这里大概说一下整个流程:
1,将除了第一张以外的图片全部隐藏,
2,获取第一张图片的alt信息显示在信息栏,并添加点击事件
3,为4个按钮添加点击侦听,点击相应的按钮,用fadeout,fadein方法显示图片
4,设置setinterval,定时执行切换函数
代码说明:
filter(:visible) :获取所有可见的元素
unbind():从匹配的元素中删除绑定的事件
siblings:取得一个包含匹配的元素集合中每一个元素的所有唯一同辈元素的元素集合
程序源码
html部分:
<body> <p id="banner"> <p id="banner_bg"></p> <p id="banner_info"></p> <ul> <li class="on">1</li> <li>2</li> <li>3</li> <li>4</li> </ul> <p id="banner_list"> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" target="_blank"><img src="imgs/img_1.jpg" title="图片" alt="图片"/></a> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" target="_blank"><img src="imgs/img_2.jpg" title="图片" alt="图片"/></a> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" target="_blank"><img src="imgs/img_3.jpg" title="图片" alt="图片"/></a> <a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" rel="external nofollow" target="_blank"><img src="imgs/img_4.jpg" title="图片" alt="图片"/></a> </p> </p> </body>
css部分:
<style type="text/css"> #banner {position:relative; width:478px; height:286px; border:1px solid #666; overflow:hidden;} #banner_list img {border:0px;} #banner_bg {position:absolute; bottom:0;background-color:#000;height:30px;filter: alpha(opacity=30);opacity:0.3;z-index:1000; cursor:pointer; width:478px;} #banner_info{position:absolute; bottom:0; left:5px;height:22px;color:#fff;z-index:1001;cursor:pointer} #banner_text {position:absolute;width:120px;z-index:1002; right:3px; bottom:3px;} #banner ul {position:absolute;list-style-type:none;filter: alpha(opacity=80);opacity:0.8; border:1px solid #fff;z-index:1002; margin:0; padding:0; bottom:3px; right:5px;} #banner ul li { padding:0px 8px;float:left;display:block;color:#fff;border:#e5eaff 1px solid;background:#6f4f67;cursor:pointer} #banner ul li.on { background:#900} #banner_list a{position:absolute;} </style>
javascript代码:
<script type="text/javascript"> var t = n =0, count; $(document).ready(function(){ count=$(#banner_list a).length; $(#banner_list a:not(:first-child)).hide(); $(#banner_info).html($(#banner_list a:first-child).find(img).attr('alt')); $(#banner_info).click(function(){window.open($(#banner_list a:first-child).attr('href'), _blank)}); $(#banner li).click(function() { var i = $(this).text() -1;//获取li元素内的值,即1,2,3,4 n = i; if (i >= count) return; $(#banner_info).html($(#banner_list a).eq(i).find(img).attr('alt')); $(#banner_info).unbind().click(function(){window.open($(#banner_list a).eq(i).attr('href'), _blank)}) $(#banner_list a).filter(:visible).fadeout(500).parent().children().eq(i).fadein(1000); document.getelementbyid(banner).style.background=; $(this).toggleclass(on); $(this).siblings().removeattr(class); }); t = setinterval(showauto(), 4000); $(#banner).hover(function(){clearinterval(t)}, function(){t = setinterval(showauto(), 4000);}); }) function showauto() { n = n >=(count -1) ?0 : ++n; $(#banner li).eq(n).trigger('click'); } </script>
相关推荐:
微信小程swiper组件实现图片轮播切换功能教程
javascript实现图片轮播效果的简单实例
jquery与css如何实现图片轮播效果的简单实例
以上就是图片轮播效果实现方法的详细内容。