angular的标签栏,有两种方法实现:

    1. 内容全部加载到页面中,再利用ng-show指令。
    2. 将每一块要加载的内容做成模板,利用ng-if指令加载。
    3. 用bootstrap的tab组件
    4. 用angular的ui-bootstrap中<tab><uib-tab>标签

  详细例子如下:

  • 1、ng-show
<script>
var App = angular.module("App",[]);
App.controller('DatailController',['$scope',function($scope){
$scope.detailDownTitle = {
title :[
"选题详情","关联内容","推荐内容","流程日志"
],
count : 0,
datailShow : function(index){
if(index==0){
this.count=0;
}else if(index==1){
this.count=1;
}else if(index==2){
this.count=2;
}else if(index==3){
this.count=3;
}else{ }
}
}]);
</script>

  HTML模板如下:

<div class="detailDown">
<ul class="detailDownTitle">
<li data-ng-repeat="title in detailDownTitle.title" data-ng-click="detailDownTitle.datailShow($index)"><a>{{title}}</a></li> //将$index传参,确定单击的哪一个Tab
</ul>

  <div data-ng-show="detailDownTitle.count==0">
    <div>Tab1</div>
  </div>
  <div data-ng-show="detailDownTitle.count==1">
    <div>Tab2</div>
  </div>
  <div data-ng-show="detailDownTitle.count==2">
    <div>Tab3</div>
  </div>

  <div data-ng-show="detailDownTitle.count==3">
    <div>Tab4</div>
  </div>

</div>

  主页index.html引入方式如下

    <div class="detailContent" data-ng-include=" 'topicDetail.html' " ng-controller= "DatailController">   //注意路径

    </div>
  • 2、ng-if

  script标签内容一样,HTML模板如下:

<div class="detailDown">
<ul class="detailDownTitle">
<li data-ng-repeat="title in detailDownTitle.title" data-ng-click="detailDownTitle.datailShow($index)"><a>{{title}}</a></li>
</ul>
<div data-ng-include=" '/topic/template/topicContent.html' " data-ng-if="detailDownTitle.count==0"></div>
<div data-ng-include=" '/topic/template/linkContent.html' " data-ng-if="detailDownTitle.count==1"></div>
<div data-ng-include=" '/topic/template/recommendContent.html' " data-ng-if="detailDownTitle.count==2"></div>
</div>
  • 3、bootstrap组件

  这里,将bootstrap官网http://v3.bootcss.com/javascript/对应的JavaScript插件代码做了些许变化。将不同的标签展示的内容引入不同的模板,而不是写死的内容。剩下的就是调整一下样式就可以了。

         <ul class="nav nav-tabs tab-layer" role="tablist">
<li role="presentation" class="active tab-list">
<a href="#topic-content" role="tab" data-toggle="tab" >选题详情</a>
</li>
<li role="presentation" class="tab-list">
<a href="#link-content" role="tab" data-toggle="tab">关联内容</a>
</li>
<li role="presentation" class="tab-list">
<a href="#recommend-content" role="tab" data-toggle="tab">推荐内容</a>
</li>
<li role="preseontation" class="tab-list">
<a href="#flow-log" role="tab" data-toggle="tab">流程日志</a>
</li>
</ul>
<div class="detail-cnt tab-content">
<div role="tabpanel" class="tab-pane active" id="topic-content" data-ng-include="'ns-topic/template/topicContent.html'"></div>
<div role="tabpanel" class="tab-pane" id="link-content" data-ng-include="'ns-topic/template/linkContent.html'"></div>
<div role="tabpanel" class="tab-pane" id="recommend-content" data-ng-include="'ns-topic/template/recommendContent.html'"></div>
<div role="tabpanel" class="tab-pane" id="flow-log" data-ng-include="'ns-topic/template/flowLog.html'"></div>
</div>
  • 4、angular的ui-bootstrap(推荐)

  查看相关api,对ui-bootstrap-tpls-0.14.0以前的版本用<tab>标签,该版本之后的用<uib-tab>标签。

            <uib-tabset active="activeJustified" justified="true">
<uib-tab index="0" heading="tab1">tab1内容</uib-tab>
<uib-tab index="1" heading="tab2">tab2内容</uib-tab>
<uib-tab index="2" heading="tab3">tab3内容</uib-tab>
</uib-tabset>

  这里引用的是最新的版本ui-bootstrap-tpls-2.3.0.min.js,大家可以在这里下载各个版本,不要忘了引入bootstrap.css,测试一下,可以吗?可以吗?可以吗?

  报错!

  报错!!

  报错!!!

  开始怀疑了,API上写的为啥不行,哪都没错啊,为啥?

  个人理解是标签不正规,但是换一种思路,将其作为属性试一下:

            <div uib-tabset active="activeJustified" justified="true">
<div uib-tab index="0" heading="tab1">tab1内容</div>
<div uib-tab index="1" heading="tab2">tab2内容</div>
<div uib-tab index="2" heading="tab3">tab3内容</div>
</div>

  done!剩下的就是稍微调整一下样式就可以了。

  最后,如果后续发现新的实现方法,会继续总结

Tab标签栏 切换 权威总结的更多相关文章

  1. html tab页面切换事件。

    $(document).bind("visibilitychange",function(e){ //只对tab页面切换有效 //document.visibilityState ...

  2. 微信小程序小技巧系列《一》幻灯片,tab导航切换

    作者:gou-tian 来自:github 幻灯片 使用微信小程序原生组件swiper实现. <swiper indicator-dots="{{indicatorDots}}&quo ...

  3. JS特效之Tab标签切换

    在我们平时浏览网站的时候,经常看到的特效有图片轮播.导航子菜单的隐藏.tab标签的切换等等.这段时间学习了JS后,开始要写出一些简单的特效.今天我也分享一个简单tab标签切换的例子.先附上代码: HT ...

  4. Android自定义控件----RadioGroup实现APP首页底部Tab的切换

    ​[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/ ...

  5. 利用target的特性,可以实现纯css的tab效果切换

    基础知识: :target起作用的是href连接到的位置 如 <a href="#tab1">tab1</a> <div id="tab1& ...

  6. jquery实现tab页切换显示div

    1.jQuery实现tab切换显示代码实现 <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" &q ...

  7. Qt之Tab键切换焦点顺序

    简介 Qt的窗口部件按用户的习惯来处理键盘焦点.也就是说,其出发点是用户的焦点能定向到任何一个窗口,或者窗口中任何一个部件. 焦点获取方式比较多,例如:鼠标点击.Tab键切换.快捷键.鼠标滚轮等. 习 ...

  8. 【Qt】Qt之Tab键切换焦点顺序【转】

    简介 Qt的窗口部件按用户的习惯来处理键盘焦点.也就是说,其出发点是用户的焦点能定向到任何一个窗口,或者窗口中任何一个部件. 焦点获取方式比较多,例如:鼠标点击.Tab键切换.快捷键.鼠标滚轮等. 习 ...

  9. ECSHOP:首页实现显示子分类商品,并实现点击Tab页切换分类商品

    例子:首页实现显示子分类商品,并实现点击Tab页切换分类商品(非AJAX) 开始:    1. 打开调试开关     文件地址:include/cls_template.php 找到 : functi ...

随机推荐

  1. jquery 节点操作大全

    $para.attr("title"); 实例: <script type="text/javascript"> //<![CDATA[ $( ...

  2. 由于权限不足而无法读取配置文件出现的HTTP 500.19解决办法

    无法访问请求的页面,因为该页的相关配置数据无效. 如下图: 解决方法, 到站点目录的属性,安全标签,添加用户(Everyone),并给修改权限:

  3. 07:打印ASCII码

    总时间限制:  1000ms 内存限制:  65536kB 描述 输入一个除空格以外的可见字符(保证在函数scanf中可使用格式说明符%c读入),输出其ASCII码. 输入 一个除空格以外的可见字符. ...

  4. Linux 下 将使用Python-Django开发的web应用布置到服务器上(亲测有效)

    写在前面: Django是一个卓越的新一代Web框架,相信使用Python的人对此并不陌生,但将我们完成的web应用布置到到服务器上并不是一件容易的事情. Django详细的教程可以参考http:// ...

  5. 浅谈iOS视频播放的N种解决方案

    简       注册登录 添加关注 作者 Maru2016.03.22 20:46* 写了4349字,被135人关注,获得了207个喜欢 字数1621 阅读2895 评论43 喜欢159 header ...

  6. 转:MySQL导入.sql文件及常用命令

    在MySQL Qurey   Brower中直接导入*.sql脚本,是不能一次执行多条sql命令的,在mysql中执行sql文件的命令: mysql> source   d:/myprogram ...

  7. poj 2492A Bug's Life

    http://poj.org/problem?id=2492 #include<cstdio> #include<cstring> #include<algorithm& ...

  8. EMV卡复位应答的时间特性 ---ISO7816协议

    1.冷复位的时间特性 图1 如图1所示: T0为200clk 从T0结束到RST变为高电平为40000-45000个clock 从RST变为高电平后,卡片必须在400-40000个clock之间应答, ...

  9. NSString copy or not (strong)?

       前些日子笔者一直在维护公司的一些旧项目,项目里面的NSString属性几乎全部用的strong,而我在给项目增加一些新的功能的,又都用的copy,因为在我的脑子里几乎已经把NSString大部分 ...

  10. ZAB协议(转)

    转自:http://www.cnblogs.com/sunddenly/articles/4073157.html Zab协议   一.ZooKeeper概述 ZooKeeper内部有一个in-mem ...