首页 >web前端 >js教程 >基于jQuery的Tab选项框效果代码(插件)_jquery

基于jQuery的Tab选项框效果代码(插件)_jquery

WBOY
WBOY原创
2016-05-16 18:09:591122浏览
复制代码如下代码:

/**
* jQuery插件
* Author: purecolor@foxmail.com
* Date : 2011-02-25
* Params:
* defaults:{
currentClass:当前样式,
trigger:触发方式,
callBack:回调函数,
auto:是否自运行,
detay:延迟时间,
index:当前位置
* }
* Return: null
* Note : Tab选项框插件
*
*/
(function($ ){
$.fn.extend({
tabBuild:function(options){
return $(this).each(function(){
var defaults={
currentClass:" currentOne",
trigger:"mouseover",
callBack:null,
auto:true,
delay:3000,
index:0
}
var params=$ .extend(默认值,选项);
var $this=$(this);
var items=$('.tab-menu',$this),i=0;
var autoTimer,curro =0;
items.each(function(){
$(this).data('lvl',i);
if(i==params.index){
$(' .tab-content',$this).eq(i).show();
$(this).addClass(params.currentClass);
}else{
$('.tab-content); ',$this).eq(i).hide();
}
i ;
$(this).bind(params.trigger,function(e){
// 删除自动运行
if(params.auto){
if(autoTimer)clearInterval(autoTimer);
}
move($(this).data("lvl")); /清除冒泡
if (e.stopPropagation) {
e.stopPropagation(); // 对于 Mozilla 和 Opera
}
else if (window.event) {
window.event .cancelBubble = true; // 对于 IE
}
});
//移动播放
function move(i){
// 删除上一个效果
items.eq(params.index).removeClass(params.currentClass);
$('.tab-content',$this).eq(params.index).hide();
//移至当前位置
items.eq(i).addClass(params.currentClass);
$('.tab-content',$this).eq(i).show();
params.index=i;
}
//自动运行
function auto(){
if(params.auto){
autoTimer=setInterval(function(){
curro=(params.index>; =2)?0:(params.index 1);
move(curro);
},params.detay);
}else{
if(autoTimer)clearInterval(autoTimer);
}
}
auto();
});
}
});
})(jQuery);

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn