jQuery 选项卡 CleverTabs
CleverTabs是一款jQuery插件,所需jQuery版本:1.6.1,jQuery UI样式版本:1.8.13;其功能为创建jQuery UI风格的Tab用于显示iframe。
本示例中符加了jQuery.contextMenu插件,我修改了其样式,使用了jQuery UI的皮肤
效果如下图:

初级应用示例:
HTML代码:
- <div id="tabs"><ul></ul></div>
Javascript代码:
- <script type="text/javascript">
- $(function(){
- tabs = $('#tabs').cleverTabs();
- tabs.add({
- url:'http://think8848.cnblogs.com',
- label:'think8848'
- });
- });
- </script>
CleverTabs详细说明:
CleverTabs为所有Tab的容器
- var tabs;
- <script type="text/javascript">
- $(function(){
- tabs = $('#tabs').cleverTabs({
- //是否安装右键菜单(默认: true)
- setupContextMenu:true,
- //右键菜单定义, 右键菜单功能由jquery.contextMenu插件提供
- //详见: http://abeautifulsite.net/2008/09/jquery-context-menu-plugin/
- //本插件中对原contextMenu插件中的样式做了修改,使用了jQuery UI皮肤
- contextMenu:{
- element: $('#contextMenuElementId'),
- handler:function(action, el, pos){/*do something...*/}
- },
- //开启Tab后是否锁定(不允许关闭,默认: false)
- lock:false,
- //开启Tab后是否禁用(不允许激活和操作iframe内容,默认: false)
- disable:false,
- //当tabs中只有一个Tab时,是否锁定该Tab(默认: true)
- lockOnlyOne:true,
- //显示iframe的容器(默认创建在tabs元素中)
- panelContainer: $('#panelContainerElementId')/*,
- 其中
- tabHeaderTemplate: '', //(Tab用于控制的头模板)
- tabPanelTemplate: '', //(Tab用于显示的Panel模板)
- uidGenerator: function() {} //(Tab唯一id生成器)
- 功能现在不启用,等有时间完善后再启用*/
- });
- tabs.add({
- url:'http://think8848.cnblogs.com',
- label:'think8848'
- });
- });
- </script>
CleverTabs.add方法
添加一个新的Tab并使之成为激活状态,如果将要添加的url已经存在,则会激活该Tab
- <script type="text/javascript">
- var tabs =('#tabs').cleverTabs();
- tabs.add({
- //必须是在tabs内唯一的id
- id:'uniqueId',
- //将要在iframe的src属性设置的值
- url:'iframe.src',
- //显示在Tab头上的文字
- label:'tab header',
- //关闭本Tab时需要刷新的Tab的url(默认: null)
- closeREfresh:'tab url',
- //关闭本Tab时需要激活的Tab的url(默认: null)
- closeActivate:'tab url',
- //关闭本Tab时需要执行的回调函数
- callback:function(){/*do something*/}
- });
- </script>
CleverTabs.getCurrentTab方法
获取当前处于激活状态的Tab
- <script type="text/javascript">
- var tabs =('#tabs').cleverTabs();
- var tab = tabs.getCurrentTab();
- </script>
CleverTabs.getTabByUrl方法
获取指定url的Tab实例
- <script type="text/javascript">
- var tabs =('#tabs').cleverTabs();
- var tab = tabs.getTabByUrl('http://think8848.cnblogs.com');
- </script>
CleverTabs.clear方法
关闭tabs内所有未锁定的Tab
- <script type="text/javascript">
- var tabs =('#tabs').cleverTabs();
- var tab = tabs.clear();
- </script>
CleverTab.deactivate方法
使Tab页面处于未激活状态,但不建议在代码中使用
CleverTab.prevTab方法:
获取该Tab之前的Tab
- <script type="text/javascript">
- var tabs =('#tabs').cleverTabs();
- var tab = tabs.getTabByUrl('http://think8848.cnblogs.com');
- var prevTab = tab.prevTab();
- </script>
CleverTab.nextTab方法
获取该Tab之后的Tab
- <script type="text/javascript">
- var tabs =('#tabs').cleverTabs();
- var tab = tabs.getTabByUrl('http://think8848.cnblogs.com');
- var prevTab = tab.nextTab();
- </script>
CleverTab.kill方法
从tabs中移移该Tab
- <script type="text/javascript">
- var tabs =('#tabs').cleverTabs();
- var tab = tabs.getTabByUrl('http://think8848.cnblogs.com');
- tab.kill();
- </script>
CleverTab.refresh方法
刷新该Tab的iframe中的内容
- <script type="text/javascript">
- var tabs =('#tabs').cleverTabs();
- var tab = tabs.getTabByUrl('http://think8848.cnblogs.com');
- tab.refresh();
- </script>
CleverTab.setDisable方法
设置该Tab的disabled属性,设置disabled为true后,自动设置该Tab的locked属性为true
- <script type="text/javascript">
- var tabs =('#tabs').cleverTabs();
- var tab = tabs.getTabByUrl('http://think8848.cnblogs.com');
- //参数true为禁用,false或不提供值为启用
- tab.setDisable(true);
- </script>
CleverTab.setLock方法
设置该Tab的locked属性,设置locked为true后,该Tab的不允许关闭
- <script type="text/javascript">
- var tabs =('#tabs').cleverTabs();
- var tab = tabs.getTabByUrl('http://think8848.cnblogs.com');
- //参数true为锁定,false或不提供值为解锁
- tab.setLock(true);
- </script>
"改变不了别人,就改变自已吧"
在现在的页面中,多数情况下都可能由几部分组成,比如:Banner,Navigator,Content等,而为了工作区域变的更大,很多时候诸如Banner,Navigator或者其他的Panel都会收起来(Collapse),这个时候问题来了,当初我给tabs定义了width: 80%; height: 90%; 现在tabs的width和height发生了变化,可是内部的Tab页面还没有收到这个变化,它还是按照之前的size显示呢,更要命的是resize事件居然只有window和body才有,div居然不支持此事件!真不知道他们是怎么想的...在之前的cleverTabs中,我绑定了window.resize事件,但是问题在于我上面举的例子中,window的size实际上没有发生变化,甚至body也没有,但是tabs的大小发生变化了,在这种情况下,如果您使用了默认的tabPenelContainer,那一定得处理tabs的resize事件,可是tabs就是一个div嘛,哪来的resize?昨晚在睡前突然想到个办法,既然能"改变不了别人,就改变自已",那么就能"自已处理不了的事,就交给别人去处理吧"。把resize“外包”出去算了。于是对原来的代码做了修改,在CleverTabs构造函数中,为CleverTabs的prototype添加了resizePanelContainer函数,tabs自已不知道发生了resize事件,但总归有人知道发生了,谁知道谁调用,所谓的能者多劳?
CleverTabs.resizePanelContainer方法:
当使用CleverTabs默认的PanelContainer时,重新设置PanelContainer的size。
- <script type="text/javascript">
- var tabs;
- $(function(){
- tabs = $('#tabs').cleverTabs();
- $(window).bind('resize',function(){
- //当发生window.resize事件时,重新默认的tabs的PanelContainer的大小
- tabs.resizePanelContainer();
- });
- </script>
jQuery 选项卡 CleverTabs的更多相关文章
- 实用的Jquery选项卡TAB
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...
- 30个实用的jQuery选项卡/导航教程推荐
很多网站设计中都使用了选项卡(tabs),在制作选项卡时应用jQuery能够实现很多炫酷的过渡和动画效果.本文为你介绍30个实用的jQuery选项卡教程,希望对你有帮助. 1. Animated Ta ...
- click事件和jquery选项卡
一. click事件 实现效果是点击切换按钮,可以重复的切换背景色 <!DOCTYPE html> <html lang="en"> <head> ...
- jQuery选项卡tabulous
jQuery选项卡tabulous,jQuery,选项卡,tab标签切换代码,扁平设计,jQuery选项卡tabulous是一款支持Scale.Slide.Scale Up.Flip等效果jquery ...
- 简单的jquery选项卡效果
html部分 <ul class="tab"> <li>最新</li> <li class="cur">热门&l ...
- jquery选项卡
用jquery实现选项卡功能 css部分: html部分: 记得一定要引入jquery文件 jquery部分:
- jQuery选项卡插件
html结构 <ul id="tabs" class="tabs"> <li data-tab="users">Us ...
- javascript与jQuery选项卡效果
HTML结构: <!doctype html><html><head><meta charset="utf-8"><title ...
- 【特效】jquery选项卡插件,页面多个选项卡统一调用
把选项卡整合了一下,写成个插件,这样可以整个站,或整个页面有多个选项卡时,统一调用.代码的具体注意事项已经写进注释了.用于js获取元素的class名称必须有,选项卡本身的样式,另再取一个名字来设置(本 ...
随机推荐
- 20145327 《Java程序设计》第五周学习总结
20145327 <Java程序设计>第五周学习总结 教材学习内容总结 try...catch:与C语言中程序流程和错误处理混在一起不同,Java中把正常流程放try块中,错误(异常)处理 ...
- 一键安装 zabbix 3.0 版本 脚本
原文地址: http://blog.csdn.net/u012449196/article/details/53859068 本文修改了原文中的部分错误,此脚本适用于zabbix 2.0 或 3.0 ...
- Import SQL into MySQL with a progress meter
There is nice tool called pv # On Ubuntu/Debian system $ sudo apt-get install pv # On Redhat/CentOS ...
- c++之单例模式
1 本篇主要讨论下多线程下的单例模式实现: 首先是 double check 实现方式: 这种模式可以满足多线程环境下,只产生一个实例. template<typename T> clas ...
- python find命令、startwith命令
python的字符串有很多好用的操作,比如find,startswith命令. 这几个命令在处理配置文件的时候很有用,比如用startswith判断是否是注释行. 注意:几个函数的返回值是不同滴. 函 ...
- canvas实现鼠标拖拽矩形移动改变大小
项目的一个新需求,动态生成矩形框,鼠标点击拖动改变矩形框的位置,并可以调整大小. 之前做过一个小demo,需求类似,但是在canvas内只有一个矩形框,拖动移动,当时记得是用isPointInPath ...
- 解决:make:cc 命令未找到的解决方法
安装Redis的时候报这个错误 原因:未安装gcc 解决方法:安装gcc 自动安装,包括依赖库[root@VM_220_111_centos redis-3.2.9]# yum -y install ...
- 《高级Web应用程序设计》课件(20170911)
第一阶段:千里之行,始于足下 第1章 ASP.NET MVC概述 第2章 音乐商店制作 第二阶段:欲穷千里目,更上一层楼 第3章 设计模型 3.1 数据模型概述 3.2 使用EF Code First ...
- AtCoder Regular Contest 078D
两边bfs,先一边找到从1到n的路径并记录下来,然后挨个标记,最后一边bfs找1能到达的点,比较一下就行了 #include<map> #include<set> #inclu ...
- 使用jQuery插件jRemoteValidate进行远程ajax验证,可以自定义返回的信息
最近项目中有一个业务是收银员通过输入用户卡号,给用户充值或者消费,但是为了避免误操作(如卡号输错),于是编写了一个远程验证的jQuery插件, 当收银员输入卡号后,失去焦点,立即ajax请求服务器端, ...