AngularJS:如何看选项卡?

时间:2013-02-18 19:12:48

标签: angularjs angularjs-directive

我正在使用angularjs标签和窗格示例组件

angular.module('components', []).
    directive('tabs', function() {
        return {
            restrict: 'E',
            transclude: true,
            scope: {},
            controller: function($scope, $element) {
                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:
                    '<div class="tabbable">' +
                        '<ul class="nav nav-tabs">' +
                            '<li ng-repeat="pane in panes" ng-class="{active:pane.selected}">'+
                                '<a href="" ng-click="select(pane)">{{pane.title}}</a>' +
                            '</li>' +
                        '</ul>' +
                        '<div class="tab-content" ng-transclude></div>' +
                    '</div>',
                replace: true
            };
        }).
    directive('pane', function() {
        return {
            require: '^tabs',
            restrict: 'E',
            transclude: true,
            scope: { title: '@' },
            link: function(scope, element, attrs, tabsCtrl) {
                tabsCtrl.addPane(scope);
            },
            template:
                '<div class="tab-pane" ng-class="{active: selected}" ng-transclude>' +
                '</div>',
            replace: true
        };
    })

SomePage.html

<tabs>
    <pane title="Datos Generales">
        <div ng-include src="'/resources/js/page/running/admin/templates/update-data.html'"></div>
    </pane>
    <pane title="Localización">
        <div ng-include src="'/resources/js/page/running/admin/templates/update-location.html'"></div>
    </pane>
    <pane title="Datos Contacto">
        <div ng-include src="'/resources/js/page/running/admin/templates/update-contacts.html'"></div>
    </pane>
    <pane title="Variantes">
        <div ng-include src="'/resources/js/page/running/admin/templates/update-variants.html'"></div>
    </pane>
</tabs>

在第二个窗格中有一个GoogleMap。我想在选择第二个窗格时刷新谷歌地图。

我不知道如何在控制器中选择选定的窗格。我已尝试$scope.panes,但undefined

1 个答案:

答案 0 :(得分:8)

以下三种方法可以解决您的问题:

  1. 在控制器上定义一个方法,在tabs元素的属性中指定该方法,使用'&amp;' tabs指令的隔离范围定义上的语法,使指令在选择窗格时调用指定的方法。
  2. 使用“selectedPane”属性在控制器的作用域上定义一个对象。在tabs指令的isolate scope定义中使用'='sytnax来启用双向数据绑定。每当选择一个窗格时设置此属性。
  3. 让标签指示$emit成为事件,并让您的控制器使用$ on来监听它。
  4. 更新:@ qopuir询问有关选项1的更多详细信息。
    假设控制器方法如下:

    $scope.paneChanged = function(pane) {
        $scope.selectedPane = pane
        ...
    }
    

    在tabs元素上,我们将使用属性pane-changed指定此函数:

    <tabs pane-changed="paneChanged(selectedPane)">
    

    然后,tabs指令可以使用'&amp;'调用此方法的语法:

    .directive('tabs', function() {
        return {
            restrict: 'E',
            transclude: true,
            scope: { paneChanged: '&' },
            controller: function($scope, $element) {
                var panes = $scope.panes = [];
    
                $scope.select = function(pane) {
                    angular.forEach(panes, function(pane) {
                        pane.selected = false;
                    });
                    pane.selected = true;
                    $scope.paneChanged({selectedPane: pane});
                }