JQuery动态添加多个tab页标签
jQuery是一个兼容多浏览器的js库,核心理念是write less,do more(写的更少,做的更多),jQuery使用户能更方便地处理HTML documents、events、实现动画效果,并且方便地为网站提供AJAX交互。
自己用到的一个主页多标签的小例子,用户登录后显示自己的相应菜单和我的主页。

代码如下:

1 <div id="right" class="content_right">
2 <div id="line">
3 <ul id="tabs">
4 <!-- Tabs go here -->
5 <li class='current'>
6 <a class='tab' id="index" href='#'>我的主页</a>
7 </li>
8 </ul>
9 </div>
10 <div id="tabcontent">
11 <!-- Tab content goes here -->
12 <div id="index_tabcontent" style="">
13 <iframe style='width:100%;height:630px;display:block;border:0' src="default.jsp"></iframe>
14 </div>
15 </div>
16 </div>

当用户点击左侧菜单是新增新的tab页标签

相应的JQuery代码如下:

1 $(document).ready(function() {
2 $("li a").click(function() {
3 if($(this).attr("id")=="index")return;
4 if ($("#" + $(this).attr("rel")).length != 0){
5 var contentname = $(this).attr("rel");
6 // hide all other tabs
7 $("#tabcontent div").hide();
8 $("#tabs li").removeClass("current");
9 // show current tab
10 $("#" + contentname +"_tabcontent").show();
11 $("#" + contentname).parent().addClass("current");
12 }else
13 addTab($(this));
14 });
15
16 $('#tabs a.tab').live('click', function() {
17 // Get the tab name
18 var contentname = $(this).attr("id") + "_tabcontent";
19
20 // hide all other tabs
21 $("#tabcontent div").hide();
22 $("#tabs li").removeClass("current");
23
24 // show current tab
25 $("#" + contentname).show();
26 $(this).parent().addClass("current");
27 });
28
29 $('#tabs a.remove').live('click', function() {
30 // Get the tab name
31 var tabid = $(this).parent().find(".tab").attr("id");
32
33 // remove tab and related content
34 var contentname = tabid + "_tabcontent";
35 $("#" + contentname).remove();
36 $(this).parent().remove();
37
38 // if there is no current tab and if there are still tabs left, show the first one
39 if ($("#tabs li.current").length == 0 && $("#tabs li").length > 0) {
40
41 // find the first tab
42 var firsttab = $("#tabs li:first-child");
43 firsttab.addClass("current");
44
45 // get its link name and show related tabcontent
46 var firsttabid = $(firsttab).find("a.tab").attr("id");
47 $("#" + firsttabid + "_tabcontent").show();
48 }
49 });
50 });
51 function addTab(link) {
52 // If tab already exist in the list, return
53 if ($("#" + $(link).attr("rel")).length != 0)
54 return;
55
56 // hide other tabs
57
58 $.ajaxSetup({cache:false});
59 $.ajax({
60 type:'post',
61 dataType:'html',
62 url:"BaseAction_getDirectUrl.jhtml?url="+$(link).attr("name")+"&nocache=" + new Date().getTime(),
63 success:function(data){
64 $("#tabs li").removeClass("current");
65 $("#tabcontent div").hide();
66
67 // add new tab and related tabcontent
68 $("#tabs").append("<li class='current'><a class='tab' id='" +
69 $(link).attr("rel") + "' href='#'>" + $(link).html() +
70 "</a><a href='#' class='remove'>x</a></li>");
71 var $div = $("<div id='" + $(link).attr("rel") + "_tabcontent'></div>");
72 var $iframe = $("<iframe style='width:100%;height:630px;display:block;border:0'></iframe>");
73 $iframe.attr("src",data);
74 $div.append($iframe);
75 $("#tabcontent").append($div);
76 },
77 error:function()
78 {
79 //错误处理
80 $.ligerDialog.open({ target: $("#errorMsg"),title:'错误代码',allowClose:false,width:450,height:180,buttons: [
81 { text: '返回首页', onclick: function (item, dialog) { parent.location.href=$('#url').val(); } }]});
82 }
83 });
84
85 // set the newly added tab as current
86 $("#" + $(link).attr("rel") + "_tabcontent").show();
87 }

代码相对简单,就不做过多说明了。
JQuery动态添加多个tab页标签的更多相关文章
- Bootstrap 基于Bootstrap和JQuery实现动态打开和关闭tab页
基于Bootstrap和JQuery实现动态打开和关闭tab页 by:授客 QQ:1033553122 1. 测试环境 JQuery-3.2.1.min.j Bootstrap-3.3.7-d ...
- Bootstrap技术: 如何给nav导航组件的tab页增加关闭按钮以及动态的添加和关闭tab页
先给出示例html代码 <div> <!-- Nav tabs --> <ul class="nav nav-tabs" role="tab ...
- 给Jquery动态添加的元素添加事件
给Jquery动态添加的元素添加事件 来源:[http://wangqixia.diandian.com/post/2011-05-10/6597866] 我想很多人都会向我一样曾经 被新元素的事件绑 ...
- [转载]给Jquery动态添加的元素添加事件
原文地址:给Jquery动态添加的元素添加事件作者:小飞侠 我想很多人都会向我一样曾经 被新元素的事件绑定困惑很久也就是在页面加载完成后给元素绑定了事件,但又新增加的元素上却没有绑定任何事件. js的 ...
- jquery 动态添加表格行
jquery 动态添加表格行 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <h ...
- jQuery动态添加删除select项
// 添加 function col_add() { var selObj = $("#mySelect"); var value="value"; var t ...
- jquery 动态添加和删除 ul li列表
今天需要实现一个jquery动态添加和删除 ul li列表中的li行,自己简单的实现乐一个,分享一下 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML ...
- jquery动态添加删除div--事件绑定,对象克隆
我想做一个可以动态添加删除div的功能.中间遇到一个问题,最后在manong123.com开发文摘 版主的热心帮助下解答了(答案在最后) 使用到的jquery方法和思想就是:事件的绑定和销毁(unbi ...
- jQuery动态添加删除CSS样式
jQuery框架提供了两个CSS样式操作方法,一个是追加样式addClass,一个是移除样式removeClass,下面通过一个小例子讲解用法. jQuery动态追加移除CSS样式 <!DOCT ...
随机推荐
- Centos7 安装rabbitmq(转载)
原文地址:http://blog.csdn.net/wenyu826/article/details/71108279 安装Erlang 从链接https://packages.erlang-solu ...
- mysql 并发测试
针对上一节做一些针对公司业务的测试. 我们来做一些压力测试. 服务器配置: 操作系统: centos 5.6-64 CPU: 8核 内存: 8G 硬盘:sas 文件系统:linux MySQL:5.6 ...
- Linux 使用代理使网速变快
$ export http_proxy="http://USER:PASSWORD@PROXY_SERVER:PORT" $ export https_proxy="ht ...
- iOS-Apple苹果iPhone开发公开API
iOS-Apple苹果iPhone开发 //技术博客http://www.cnblogs.com/ChenYilong/ 新浪微博http://weibo.com/luohanchenyilo ...
- 使用.net core abp framework
abp是一个有用的框架,包含许多功能,可以用来作为脚手架. 直接在官方网站上输入相应的工程名称,选择对应的版本就会下载对应的版本..net core 版本的可以使用后端框架部分来做api,包含了常用框 ...
- linux驱动基础系列--Linux mmc sd sdio驱动分析
前言 主要是想对Linux mmc子系统(包含mmc sd sdio)驱动框架有一个整体的把控,因此会忽略某些细节,同时里面涉及到的一些驱动基础,比如平台驱动.块设备驱动.设备模型等也不进行详细说明原 ...
- 神秘的subsys_initcall【转】
转自:http://blog.chinaunix.net/uid-12567959-id-161015.html 在内核代码里到处都能看到这个subsys_initcall(),而它到底是干什么的呢? ...
- python设计模式之单例模式(一)
单例设计模式的概念: 单例设计模式即确保类有且只有一个特定类型的对象,并提供全局访问点.一般我们操作数据库的时候为了避免统一资源产生互相冲突,创建单例模式可以维护数据的唯一性. 单例模式的特性: 确保 ...
- MVC自定义路由实现URL重写,SEO优化
//App_Start-RouteConfig.cs public class RouteConfig { public static void RegisterRoutes(RouteCollect ...
- 设计模式之笔记--抽象工厂模式(Abstract Factory)
抽象工厂模式(Abstract Factory) 定义 抽象工厂模式(Abstract Factory),提供一个创建一系列相关或相互依赖对象的接口,而无需指定它们具体的类. 类图 描述 多个抽象产品 ...