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页标签的更多相关文章

  1. Bootstrap 基于Bootstrap和JQuery实现动态打开和关闭tab页

    基于Bootstrap和JQuery实现动态打开和关闭tab页   by:授客 QQ:1033553122 1.   测试环境 JQuery-3.2.1.min.j Bootstrap-3.3.7-d ...

  2. Bootstrap技术: 如何给nav导航组件的tab页增加关闭按钮以及动态的添加和关闭tab页

    先给出示例html代码 <div> <!-- Nav tabs --> <ul class="nav nav-tabs" role="tab ...

  3. 给Jquery动态添加的元素添加事件

    给Jquery动态添加的元素添加事件 来源:[http://wangqixia.diandian.com/post/2011-05-10/6597866] 我想很多人都会向我一样曾经 被新元素的事件绑 ...

  4. [转载]给Jquery动态添加的元素添加事件

    原文地址:给Jquery动态添加的元素添加事件作者:小飞侠 我想很多人都会向我一样曾经 被新元素的事件绑定困惑很久也就是在页面加载完成后给元素绑定了事件,但又新增加的元素上却没有绑定任何事件. js的 ...

  5. jquery 动态添加表格行

    jquery 动态添加表格行 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <h ...

  6. jQuery动态添加删除select项

    // 添加 function col_add() { var selObj = $("#mySelect"); var value="value"; var t ...

  7. jquery 动态添加和删除 ul li列表

    今天需要实现一个jquery动态添加和删除  ul li列表中的li行,自己简单的实现乐一个,分享一下 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML ...

  8. jquery动态添加删除div--事件绑定,对象克隆

    我想做一个可以动态添加删除div的功能.中间遇到一个问题,最后在manong123.com开发文摘 版主的热心帮助下解答了(答案在最后) 使用到的jquery方法和思想就是:事件的绑定和销毁(unbi ...

  9. jQuery动态添加删除CSS样式

    jQuery框架提供了两个CSS样式操作方法,一个是追加样式addClass,一个是移除样式removeClass,下面通过一个小例子讲解用法. jQuery动态追加移除CSS样式 <!DOCT ...

随机推荐

  1. JS利用 Sea.js 实现模块化:拖拽、缩放及范围限制

    知识点总结: Sea.js的使用:define.export.seajs.use.require等方法:   参考:http://seajs.org/docs/ Sea.js与require.js的区 ...

  2. 耗子学Python了(1)___Python环境配置

    一:写在开始的开始 最近我们团对的老大问我想看什么书,我让老大买了一本<Python 3面向对象编程>,所以在看的时候边敲边实践,决定在自己电脑配置下相应的环境,然后开始Python的学习 ...

  3. java有关Time类型数据的接收和转换

    一:前言 有关Time的时间其实很少有用到.但是用到就很纠结了,转换和保存,都是烦人的事情,我自己就在这上面吃过一个亏,所以就加载下来吧! 二:内容 (1):被坑的地方 实体类 import java ...

  4. 【hdu1255】线段树求矩形面积交

    题意大概就是上图这个样子.<=100组测试数据,每组<=1000个矩形. 题解: 这个问题怎么解决..做了上一题矩形面积并应该就会了.. 对于每个节点维护3个值: cnt:该节点所代表的这 ...

  5. 【BZOJ4817】【SDOI2017】树点涂色 [LCT][线段树]

    树点涂色 Time Limit: 10 Sec  Memory Limit: 128 MB[Submit][Status][Discuss] Description Bob有一棵n个点的有根树,其中1 ...

  6. Html5学习2(Html表格、Html列表、Html5新元素、Canvas (坐标、路径、画圆、文本、渐变、图像))

    Html表格 1.表格中的表头:<th></th>.其中表头部分字体加粗,颜色深绿色 <h4>水平标题:</h4> <table border=& ...

  7. Quick-Cocos2dx-Community_3.6.3_Release 编译时libtiff.lib 无法解析

    Quick-Cocos2dx-Community_3.6.3_Release 使用VS2012编译,报错: libtiff.lib lnk2001 无法解析的外部符号 ltod3 类似于上面这种,刚才 ...

  8. elementui input样式覆盖 头部小图等

    .nav-right >>> .keywords .el-input__inner { -webkit-appearance: none; background-color: #F3 ...

  9. ES6新用法

    ES6 详细参考页面 简介 ECMAScript和JavaScript的关系是,前者是后者的规格,后者是前者的一种实现.一般来说,这两个词是可以互换的. let命令 ES6新增了let命令,用来声明变 ...

  10. js_页面关闭beforeunload事件

    做圆桌爆文公众号的时候,需要对阅读的文章进行时间统计.是这个公众号的核心功能,客户把文章转发到朋友圈或者转给朋友,记录谁阅读此文章和阅读时长进行记录,从而展示给客户. 功能点是,关闭页面时触发事件,请 ...