1200字范文,内容丰富有趣,写作的好帮手!
1200字范文 > Tab切换组件(选项卡功能)实例代码【jquery】

Tab切换组件(选项卡功能)实例代码【jquery】

时间:2022-06-02 07:55:47

相关推荐

Tab切换组件(选项卡功能)实例代码【jquery】

web前端|js教程

切换组件,选项卡

web前端-js教程

直接贴代码里面有注释:

网站源码防止下载,ubuntu+共享上网,用什么除爬虫,resin php配置,seo聚合手法lzw

/**

* 简单的Tab切换

* 支持可配置项 如下参数

*/

function Tab(){

this.config = {

type : mouseover, //类型 默认为鼠标移上去

autoplay : true, // 默认为自动播放

triggerCls: .list, // 菜单项

panelCls : .tabContent, // 内容项

index : 0, // 当前的索引0

switchTo : 0, // 切换到哪一项

interval : 3000, // 自动播放间隔时间 默认为3 以s为单位

pauseOnHover : true, // 鼠标放上去是否为暂停 默认为true

current : current,// 当前项添加到类名

hidden: hidden, // 类名 默认为hidden

callback : null // callback函数

};

this.cache = {

timer : undefined,

flag : true

};

}

Tab.prototype = {

init: function(options){

this.config = $.extend(this.config,options || {});

var self = this,

_config = self.config;

self._handler();

},

_handler: function(){

var self = this,

_config = self.config,

_cache = self.cache,

len = $(_config.triggerCls).length;

$(_config.triggerCls).unbind(_config.type);

$(_config.triggerCls).bind(_config.type,function(){

_cache.timer && clearInterval(_cache.timer);

var index = $(_config.triggerCls).index(this);

!$(this).hasClass(_config.current) &&

$(this).addClass(_config.current).siblings().removeClass(_config.current);

$(_config.panelCls).eq(index).removeClass(_config.hidden).siblings().addClass(_config.hidden);

// 切换完 添加回调函数

_config.callback && $.isFunction(_config.callback) && _config.callback(index);

});

// 默认情况下切换到第几项

if(_config.switchTo) {

$(_config.triggerCls).eq(_config.switchTo).addClass(_config.current).siblings().removeClass(_config.current);

$(_config.panelCls).eq(_config.switchTo).removeClass(_config.hidden).siblings().addClass(_config.hidden);

}

// 自动播放

if(_config.autoplay) {

start();

$(_config.triggerCls).hover(function(){

if(_config.pauseOnHover) {

_cache.timer && clearInterval(_cache.timer);

_cache.timer = undefined;

}else {

return;

}

},function(){

start();

});

}

function start(){

_cache.timer = setInterval(autoRun,_config.interval);

}

function autoRun() {

if(_config.switchTo && (_config.switchTo == len-1)){

if(_cache.flag) {

_config.index = _config.switchTo;

_cache.flag = false;

}

}

_config.index++;

if(_config.index == len) {

_config.index = 0;

}

$(_config.triggerCls).eq(_config.index).addClass(_config.current).siblings().removeClass(_config.current);

$(_config.panelCls).eq(_config.index).removeClass(_config.hidden).siblings().addClass(_config.hidden);

}

}

};

页面上调用方式如下:

管家婆源码,vscode清除设置,对ubuntu的感觉,tomcat部署更新,sqlite 时间分组查询,ecshop 每日签到插件,前端框架导出成员方式,论坛收费文件爬虫,php nginx配置,沈阳seo技术,源代码下载音乐网站,手机网页 视频播放失败,手机版网站模板框架,滚动条 页面,新云网站管理系统5,dz微博程序lzw

$(function(){

new Tab().init({

switchTo: 1,

callback: function(index){

console.log(index);

}

});

});

房子中介源码,ubuntu主机密码,全网爬虫的克星,函数php,地产seo报价lzw

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。