AngularJS實現(xiàn)tab選項卡的方法詳解
本文實例講述了AngularJS實現(xiàn)tab選項卡的方法。分享給大家供大家參考,具體如下:
一、代碼實現(xiàn)
<!DOCTYPE html>
<html ng-app='app'>
<head>
<meta charset="UTF-8">
<title></title>
<style>
*{
list-style: none;
margin: 0;
padding: 0;
}
.TabNav{
height: 131px;
width: 450px;
position: relative;
margin-left: auto;
margin-right: auto;
margin-top: 100px;
}
.TabNav ul li{
float: left;
background: -webkit-gradient(linear,left top,left bottom, from(#fefefe), to(#ededed));
border: 1px solid #ccc;
padding: 5px 0;
width: 100px;
text-align: center;
margin-left: -1px;
position: relative;
cursor: pointer;
}
.TabCon{
position: absolute;
left: -1px;
top: 30px;
border: 1px solid #ccc;
border-top: none;
width: 403px;
height: 100px;
}
.TabNav ul li.active{
background: #FFFFFF;
border-bottom: none;
}
</style>
<script src="js/angular.min.js" type="text/javascript" charset="utf-8"></script>
</head>
<body>
<div class="TabNav">
<ul ng-init='activeTab=1'>
<li ng-class='{active:activeTab==1}' ng-click='activeTab=1'>許嵩</li>
<li ng-class='{active:activeTab==2}' ng-click='activeTab=2'>周杰倫</li>
<li ng-class='{active:activeTab==3}' ng-click='activeTab=3'>林俊杰</li>
<li ng-class='{active:activeTab==4}' ng-click='activeTab=4'>陳奕迅</li>
</ul>
<div class="TabCon">
<div ng-show='activeTab==1'>斷橋殘雪、千百度、幻聽、想象之中</div>
<div ng-show='activeTab==2'>紅塵客棧、牛仔很忙、給我一首歌的時間、聽媽媽的話</div>
<div ng-show='activeTab==3'>被風(fēng)吹過的夏天、江南、一千年以后</div>
<div ng-show='activeTab==4'>十年、K歌之王、浮夸</div>
</div>
</div>
</body>
<script type="text/javascript">
var app=angular.module('app',[]);
app.controller('tabcontroller',function($scope){
var vm=$scope.vm;
});
</script>
</html>
二、效果預(yù)覽

三、實現(xiàn)原理
選項卡的內(nèi)容是顯示還是隱藏是由activeTab的值決定的,而這個值是通過選項卡上面的ng-click指令設(shè)置的,當(dāng)對應(yīng)選項卡的內(nèi)容顯示的時候,給點擊的按鈕添加樣式,這樣做雖然也能實現(xiàn)選項卡的內(nèi)容,但是這樣做的的弊端是,選項卡的內(nèi)容是固定的,不好去改變,所以接下來我們將上面的代碼改成下面這種形式
四、改版
<!DOCTYPE html>
<html ng-app='app'>
<head>
<meta charset="UTF-8">
<title></title>
<style>
*{
list-style: none;
margin: 0;
padding: 0;
}
.TabNav{
height: 131px;
position: relative;
margin-left: 100px;
margin-top: 100px;
}
.TabNav ul li{
float: left;
background: -webkit-gradient(linear,left top,left bottom, from(#fefefe), to(#ededed));
border: 1px solid #ccc;
padding: 5px 0;
width: 100px;
text-align: center;
margin-left: -1px;
position: relative;
cursor: pointer;
}
.TabCon{
position: absolute;
left: -1px;
top: 30px;
border: 1px solid #ccc;
border-top: none;
width: 403px;
height: 100px;
}
.TabNav ul li.active{
background: #FFFFFF;
border-bottom: none;
}
</style>
<script src="js/angular.min.js" type="text/javascript" charset="utf-8"></script>
</head>
<body>
<div class="TabNav" ng-controller='tabcontroller'>
<ul ng-init='selected=0'>
<li ng-class='{active:selected==$index}' ng-click='show($index)' ng-repeat='item in vm'>{{item.list}}</li>
</ul>
<div class="TabCon">
<div ng-show='selected==$index' ng-repeat='item in vm'>{{item.con}}</div>
</div>
</div>
</body>
<script type="text/javascript">
var app=angular.module('app',[]);
app.controller('tabcontroller',function($scope){
$scope.vm=[
{"list":"許嵩","con":"斷橋殘雪、千百度、幻聽、想象之中"},
{"list":"周杰倫","con":"紅塵客棧、牛仔很忙、給我一首歌的時間、聽媽媽的話"},
{"list":"林俊杰","con":"被風(fēng)吹過的夏天、江南、一千年以后"},
{"list":"陳奕迅","con":"十年、K歌之王、浮夸"}
];
var selected=$scope.selected;
$scope.show=function(index){
$scope.selected=index;
};
});
</script>
</html>
說明:vm這個數(shù)組里面是我們自己定義的一些假數(shù)據(jù)(這個數(shù)據(jù)實際上是可以從后臺獲取的),然后我們通過ng-repeat指令循環(huán)遍歷出vm里面的數(shù)據(jù),插入到頁面中,$index是每個內(nèi)容對象的索引值
更多關(guān)于AngularJS相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《AngularJS指令操作技巧總結(jié)》、《AngularJS入門與進階教程》及《AngularJS MVC架構(gòu)總結(jié)》
希望本文所述對大家AngularJS程序設(shè)計有所幫助。
相關(guān)文章
indexedDB bootstrap angularjs之 MVC DOMO (應(yīng)用示例)
這篇文章主要介紹了indexedDB bootstrap angularjs之 MVC DOMO (應(yīng)用示例)的相關(guān)資料,需要的朋友可以參考下2016-06-06
angular4 共享服務(wù)在多個組件中數(shù)據(jù)通信的示例
本篇文章主要介紹了angular4 共享服務(wù)在多個組件中數(shù)據(jù)通信的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03
Angularjs中如何使用filterFilter函數(shù)過濾
這篇文章主要介紹了Angularjs中如何使用filterFilter函數(shù)過濾的相關(guān)資料,需要的朋友可以參考下2016-02-02
詳解Angular 中 ngOnInit 和 constructor 使用場景
最初學(xué)習(xí)Angular的時候總是搞不清楚ngOnInit和constructor的區(qū)別,現(xiàn)在我們來稍微理一下兩者之間的區(qū)別。2017-06-06
AngularJS遞歸指令實現(xiàn)Tree View效果示例
這篇文章主要介紹了AngularJS遞歸指令實現(xiàn)Tree View效果,結(jié)合實例形式分析了AngularJS基于遞歸指令實現(xiàn)樹形結(jié)構(gòu)層次數(shù)據(jù)的相關(guān)操作步驟與注意事項,需要的朋友可以參考下2016-11-11
Angularjs根據(jù)json文件動態(tài)生成路由狀態(tài)的實現(xiàn)方法
最近做項目遇到這樣一個新需求,就是需要根據(jù)json文件動態(tài)生成路由狀態(tài),通過查閱相關(guān)資料實現(xiàn)了此功能,下面小編把問題總結(jié)分享到腳本之家平臺供大家參考2017-04-04
Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output詳解 (上)
這篇文章主要給大家介紹了關(guān)于Angular 2父子組件數(shù)據(jù)傳遞之@Input和@Output的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面跟著小編一起來看看吧。2017-07-07

