本文实例讲述了jquery简单自定义图片轮播插件及用法。分享给大家供大家参考,具体如下:
经常使用别人的插件,现在自己写一个,纪念一下。
jquery.banner.js:
/*
* banner 0.1
* 使用banner 实现图片定时切换 鼠标经过停止动画
* 鼠标离开,继续动画
*/
;(function($){
$.fn.banner =function(options){
//各种属性和参数
var defaults ={
picwidth:"1000",
picheight:"300",
speed:"1500"
};
var totalw = 0; //保存总的动画宽度
var timer = null; //保存定时器
var current = 0; //保存当前动画到第n张图,下次从这里开始
var totalnum = 0; //保存总的图数
var dsqtime = 0; //定义定时器时间 【外传参数】
var dhtime = 0; //定义动画时间
var count = 0 ;
//合并多个对象为一个,即有新参数 用新的,否则用默认的
var options = $.extend(defaults, options);
this.each(function(){
//实现代码
var __this = $(this);
dsqtime = options.speed;
dhtime = dsqtime/3;
//初始化
init(__this);
//调用动画
show(__this, options.picwidth,current);
//鼠标经过时事件
__this.find('ul li').bind('mouseover',function(){
window.clearinterval(timer); //清除定时器
});
__this.find('ul li').bind('mouseout',function(){
show(__this, options.picwidth,current);
//接着上一次动画轮播
});
});
//初始化 设定父容器宽度
function init(obj){
obj.find('ul li').each(function(){
totalw += $(this).width();
totalnum++;
});
obj.find('ul').width(totalw);
}
//开始动画显示
function show(obj, width, current){
timer = setinterval(function(){
obj.find('ul').animate({'margin-left':'-'+count*width+'px'},
dhtime);
current = count;
count++;
if(count == totalnum){
count =0;
}
}, dsqtime);
}
};
})(jquery);
html代码:
<!doctype html>
<html>
<head>
<meta charset="utf8"/>
<script type="text/javascript" src="./js/jquery.min.js"></script>
<script type="text/javascript" src="./js/jquery.banner.js"></script>
<script type="text/javascript">
$(document).ready(function(){
$('.wrap').banner({
picwidth:"1000",
picheight:"300",
speed:"6000"
});
});
</script>
<style type="text/css">
*{margin:0;padding:0;}
.wrap{width:1000px; height:300px; overflow:hidden; margin:0 auto;}
.wrap ul li{float:left; list-style:none;}
.wrap ul li img{width:1000px;height:300px;}
.clear{clear: both;}
</style>
</head>
<body>
<div>
<div class="wrap">
<ul>
<li><a href="#"><img src="./images/1.jpg"/></a></li>
<li><a href="#"><img src="./images/2.jpg"/></a></li>
<li><a href="#"><img src="./images/3.jpg"/></a></li>
<li><a href="#"><img src="./images/4.jpg"/></a></li>
<li><a href="#"><img src="./images/5.jpg"/></a></li>
</ul>
<div class="clear"></div>
</div>
</div>
</body>
</html>
效果图: