javascript - angularjs代码阅读, tabsCtrl.addPane(scope)参数为何是scope?
PHPz
PHPz 2017-04-11 12:30:36
[JavaScript讨论组]
directive('tabs', function() {
return {
            restrict: 'E',
            transclude: true,
            scope: {},
            controller: ["$scope", function($scope) {
                var panes = $scope.panes = [];                
                $scope.select = function(pane) {
                    angular.forEach(panes, function(pane) {
                        pane.selected = false;
                    });
                    pane.selected = true;
                }
 
                this.addPane = function(pane) {
                    if(panes.length == 0) $scope.select(pane);
                    panes.push(pane);
                }
            }],
            template: '

' + '

' + '

' + '

', replace: true }; }). directive('pane', function() { return { require: '^tabs',// restrict: 'E', transclude: true, scope: { title: '@' }, link: function(scope, element, attrs, tabsCtrl) { tabsCtrl.addPane(scope);//这里为什么传scope参数呢 }, template: '

' +//ng-class="{active: selected}"怎么理解呢 '

', replace: true }; })
PHPz
PHPz

学习是最好的投资!

全部回复(1)
大家讲道理

controller里边有select和addPane所有用数组,
ng-repeat="pane in panes" 是一个循环吧所有传入的是pane
ng-class="{active: selected}" 当被选择的时候激活class
个人理解,仅供参考
还是angular2好理解

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号