有没有办法只使用子指令作为占位符来保存内容?

时间:2012-06-01 00:38:58

标签: javascript angularjs

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

我尝试了类似上面的内容,但没有任何内容被推入窗格。似乎永远不会调用子指令(窗格)的链接功能。因此,只显示添加标签的链接。

有什么想法吗?

2 个答案:

答案 0 :(得分: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>

答案 1 :(得分:0)

也许它不起作用的原因是因为在你的child指令中你没有模板。如果没有模板,指令就不知道在何处以及如何呈现指令。

你能做的就是:

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

在您的子模板中..

并且您的element.text()仍应有效!

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

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