1

我是 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;
      }

      $scope.createPane = function() {
        var pane = panes[panes.length - 1];
        var clonedPane = Angular.copy(pane);
        panes.push(clonedPane);
      }

      this.addPane = function(pane) {
        if (panes.length == 0) $scope.select(pane);
        panes.push(pane);
      }
    },
    template: '<div class="tabbable tabs-left">' +
      '<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>' +
      '<li ng-class="addLink"><a ng-click="createPane()"><i class="icon-plus"></i> tab</a></li>' +
      '</ul>' +
      '<div class="tab-content">' +
      '<div ng-repeat="pane in panes" class="tab-pane" ng-class="{active: selected},{{pane.pclass}}" id="{{pane.id}}">' +
      '{{ pane.content }}' +
      '</div>' +
      '</div>' +
      '</div>',
    replace: true
  };
}).
directive('pane', function() {
  return {
    require: '^tabs',
    restrict: 'E',
    scope: {
      title: 'bind',
      pclass: 'bind',
      id: 'bind'
    },
    link: function(scope, element, attrs, tabsCtrl) {
      var text = element.text();
      tabsCtrl.addPane({
        title: scope.title,
        pclass: scope.pclass,
        id: scope.id,
        content: text
      });
    }
  };
})

对应的html代码:

<tabs>
  <pane title="tab 1" id="tab1" pclass="tab">
    hello
  </pane>
  <pane title="tab 2" id="tab2" pclass="tab">
    world
  </pane>
</tabs>

我尝试了类似上面的方法,但没有任何东西被推入窗格。似乎永远不会调用子指令(窗格)的链接函数。因此,仅显示添加选项卡的链接。

有任何想法吗?

4

2 回答 2

1

解决这个问题的最简单(虽然有点烦人)的方法是为每个窗格设置一个模板。

在 html 中:

<tabs>
  <pane title="tab 1" id="tab1" pclass="tab" template="pane1-templ">
  </pane>
  <pane title="tab 2" id="tab2" pclass="tab" template="pane2-templ">
  </pane>
</tabs>
<script type="text/ng-template" src="pane1-template">hello</script>
<script type="text/ng-template" src="pane2-template>wolrd</script>

在您的指令中:

'<div class="tab-content">' + 
    '<div ng-repeat="pane in panes" class="tab-pane" ng-class="{active: selected},{{pane.pclass}}" id="{{pane.id}}">' + 
         '<div ng-include src="pane.template"></div>' +
    '</div>' +
'</div>'

或者..您是否尝试过这样做来解决它?

在窗格中:

var html = elm.html();
//...
pane.html = html;

在选项卡中:

<div ng-bind-html-unsafe="pane.html"></div>
于 2012-06-02T03:20:40.540 回答
0

也许它不起作用的原因是因为在您的子指令中您没有模板。没有模板,指令不知道在哪里以及如何呈现指令。

你可以做的是有这样的事情:

template : '<div style="display:none;" ng-transclude></div>'

在您的子模板中..

element.text()应该仍然可以工作!

如果没有模板,链接函数将永远无法获得,element因此您的子指令将在那里失败。

使用上面的模板应该可以工作。

于 2012-06-01T09:48:32.047 回答