用AngularJS的指令实现tabs切换效果
2016-08-31 14:36
1086 查看
先来看看效果图
首先先来说一下指令嵌套,指令嵌套顾名思义就是两个以上的指令嵌套在一起,比如下面这样:
<A-deirective> <B-directive></B-directive> <C-directive></C-directive> </A-directive>
下面这个tabs功能的指令,刚好用到了这个,可以让代码更加简洁。
<!DOCTYPE html> <html lang="en" ng-app="docsTabsExample"> <head> <meta charset="UTF-8"> <title></title> <script></script> <script src="lib/angular.min.js" type="text/javascript"></script> <script src="lib/angular-route.js" type="text/javascript"></script> <script src="lib/jquery-2.1.4.min.js"></script> <script src="lib/bootstrap.js" type="text/javascript"></script> <link rel="stylesheet" href="css/bootstrap.css" type="text/css"/> <style> .active{ background: red; } </style> </head> <body ng-controller="appCon"> <my-tabs><!--最外层指令--> <my-pane tittle="ONE"><!--内层指令--> <h4>One</h4> <p>angularangularangularangularangularangularangular</p> </my-pane> <my-pane tittle="TWO"><!--内层指令--> <h4>Two</h4> <p>angularangularangularangularangularangularangular</p> </my-pane> <my-pane tittle="THERE"><!--内层指令--> <h4>There</h4> <p>bootstrapbootstrapbootstrapbootstrapbootstrapbootstrap</p> </my-pane> <my-pane tittle="FIVE"><!--内层指令--> <h4>five</h4> <p>jqueryjqueryjqueryjqueryjqueryjqueryjquery</p> </my-pane> </my-tabs> </body> <script> var app=angular.module("docsTabsExample",['template']) .controller("appCon",["$scope",function($scope){ }]) .directive("myTabs", function () { return{ restrict:"EA", transclude: true, scope:{}, templateUrl:"myTabs.html", controller:["$scope", function ($scope) {//使用controller让最内层指令来继承外层指令,这样内层就可以通过scope的传导,来与外层指令进行数据之间的传递 var panes = $scope.scopes = [];// $scope.select= function (pane) {//实现tabs功能 angular.forEach(panes, function (scope) { //遍历所有内存指令scope,统一隐藏内容。 scope.selected=false; }); pane.selected=true;//通过ng-repeat只 }; this.addScope= function (scope) {//由内层指令来继承,把内层指令的scope,传到进外层指令进行控制 if(panes.length===0){ $scope.select(scope); } panes.push(scope);//把内层指令数组,传入外层指令scope数组。 } }] } }) .directive("myPane", function () { return{ restrict:'EA', scope:{ tittle:'@' }, transclude: true, require:'^myTabs',//继承外层指令 templateUrl:"myPane.html", link: function (scope, elemenet,attrs,myTabsController) { myTabsController.addScope(scope);//把内层指令的scope存入到外层指令中,让外层遍历。 } } }); angular.module("template",[]) .run(["$templateCache", function ($templateCache) { $templateCache.put("myTabs.html","<div class='table'>" + "<ul class='nav nav-tabs'>" + "<li ng-repeat='pane in scopes' ng-class='{active:pane.selected}'>" + "<a href='#' ng-click='select(pane)'>{{pane.tittle}}<a/>" + "</li>" + "</ul>" + "<div ng-transclude class='tab-content'></div>" + "</div>") }]) .run(["$templateCache", function ($templateCache) { $templateCache.put("myPane.html","<div class='table-pane' ng-show='selected' ng-transclude>" + "</div>") }]) </script> </html>
整个指令的的实现原理就是通过指令的继承,把内层指令的
scope暴露到外层指令中,这样就可以在外层指令控制内层指令的显示。这里还有另外一个要说明的,为了让指令更加有层次,更加有逻辑性,使用了
ng-transclude,让指令的
template内容,反向插入到标有
ng-transclude的内容中。
结束语
好了,以上就是AngularJS通过指令实现tabs切换功能的全部内容,大家都学会了吗?希望对大家学习AngularJS能有所帮助,如果有疑问可以留言交流。谢谢大家对脚本之家的支持。
您可能感兴趣的文章:
相关文章推荐
- AngularJS递归指令实现Tree View效果示例
- AngularJS2中一种button切换效果的实现方法(二)
- Vue.js组件tabs实现选项卡切换效果
- h5用swiper结合angularjs实现手机浏览器左右滑动切换图片的效果
- ionic2 使用tabs+slides实现滑动切换页面效果
- javascript实现tabs选项卡切换效果(扩展版)
- 使用AngularJS2中的指令实现按钮的切换效果
- javascript实现tabs选项卡切换效果(自写原生js)
- javascript实现tabs选项卡切换效果(扩展版)
- 4000 通过AngularJs实现Tab选项卡切换效果
- angularjs实现原生APP页面切换效果
- Vue.js组件tabs实现选项卡切换效果
- javascript实现tabs选项卡切换效果(自写原生js)
- android:ViewPager实现Tabs滑动切换效果
- .net里实现图片切换的效果/C#实现图片切换的效果
- 在DNN站点中加上Tabs效果,并实现在tab中添加模块
- JQuery学习笔记 实现图片翻转效果和TAB标签切换效果第1/2页
- 37个Ajax和CSS实现的Tab选项卡切换效果界面
- 方法自身实现异部调用和WinForm上图片切换效果
- 37个Ajax和CSS实现的Tab选项卡切换效果界面【转载】