angularjs - 在指令中包装 md-tabs 会产生 "Orphan ngTransclude Directive"错误

标签 angularjs angularjs-directive angularjs-scope angular-material angularjs-ng-transclude

我想创建一个包装 md-tabs 的指令,但我收到一个错误,“Orphan ngTransclude Directive”。我已经复制了这个片段中的错误:

angular.module('transcludeExample', ['ngMaterial'])
   .directive('worksGreat', function(){
      return {
        restrict: 'E',
        transclude: true,
        template: '<ng-transclude></ng-transclude>'
      };
  })
  .directive('doesntWork', function(){
      return {
        restrict: 'E',
        transclude: true,
        template: '' + 
         '<md-tabs md-dynamic-height>' +
           '<md-tab label=\'tab 1\'>' + 
             '<ng-transclude></ng-transclude>' +
           '</md-tab>' +
         '</md-tabs>'
      };
  })
<!doctype html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Example - example-simpleTranscludeExample-production</title>
  
  <link rel="stylesheet" href="https://ajax.googleapis.com/ajax/libs/angular_material/0.11.2/angular-material.min.css">
</head>
<body ng-app="transcludeExample">
  <!-- Angular Material Dependencies -->
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular.js"></script>
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular-animate.js"></script>
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular-aria.js"></script>

    <!-- Angular Material Javascript using GitCDN to load directly from `bower-material/master` -->
    <script src="https://gitcdn.link/repo/angular/bower-material/master/angular-material.js"></script>

<div>
  <h3>ng-transclude in a directive works great:</h3>
  <works-great>Inner text</works-great>
  <hr/>
  
  <h3>md-tabs without a directive works great:</h3>
  <md-tabs md-dynamic-height>
    <md-tab label="tab 1">
      Inner text
    </md-tab>
  </md-tabs>
  <hr/>
  
  <h3>combining md-tabs with a directive doesn't work:</h3>
  <doesnt-work>Inner text</doesnt-work>
</div>
</body>
</html>

我找到了 this answer进入手动操作模板之外的元素,但我希望有一种更清晰的“更有 Angular ”的方式。这里发生了什么?有没有一种方法可以定义 ng-transclude 应该应用于什么指令?

最佳答案

This comment on github提出解决方案。 ng-transclude 被设计为通用的,因此它可以与任何指令一起使用,但在这种情况下,这就是问题所在。幸运的是,模仿起来非常简单,我们可以使用 require 指定它应该应用于哪个父级。

我已经用有效的解决方案更新了我的代码片段:

var orphanDemoCtrl = function($transclude){
  this.$transclude = $transclude;
}

angular.module('transcludeExample', ['ngMaterial'])
  .controller('orphanDemoCtrl', orphanDemoCtrl)
  .directive('orphanDemo', function(){
      return {
        restrict: 'E',
        transclude: true,
        template: '' + 
         '<md-tabs md-dynamic-height>' +
           '<md-tab label=\'tab 1\'>' + 
             '<orphan-demo-transclude></orphan-demo-transclude>' +
           '</md-tab>' +
         '</md-tabs>',
        controller: orphanDemoCtrl
      };
  })
  .directive('orphanDemoTransclude', function(){
      return {
        require: "^orphanDemo",
        link: function($scope, $element, $attrs, orphanDemoCtrl){
          orphanDemoCtrl.$transclude(function(clone) {
            $element.empty();
            $element.append(clone);
          });
        }
     }
  })
<!doctype html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <title>Example - example-simpleTranscludeExample-production</title>
  
  <link rel="stylesheet" href="https://ajax.googleapis.com/ajax/libs/angular_material/0.11.2/angular-material.min.css">
</head>
<body ng-app="transcludeExample">
  <!-- Angular Material Dependencies -->
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular.js"></script>
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular-animate.js"></script>
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular-aria.js"></script>

    <!-- Angular Material Javascript using GitCDN to load directly from `bower-material/master` -->
    <script src="https://gitcdn.link/repo/angular/bower-material/master/angular-material.js"></script>

<div>  
  <h3>combining md-tabs with a directive works now:</h3>
  <orphan-demo>Inner text</orphan-demo>
</div>
</body>
</html>

关于angularjs - 在指令中包装 md-tabs 会产生 "Orphan ngTransclude Directive"错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38127720/

相关文章:

javascript - 使用 OPTIONS 方法代替 POST

javascript - 改进 AngularJS 指令代码

javascript - angularjs 范围绑定(bind)和 rootscope

angularjs - 在可重用的 Angular 指令中隔离范围

javascript - 在 Controller 范围内使用指令时不保留 $scope

Javascript 拼接数组只是替换值而不是删除它

javascript - 尝试在 AngularJS 中创建多重过滤器以按月份和年份 ID 过滤 JSON 数据

angularjs - 使用 Angular 指令会导致错误 : 10 $digest() iterations reached. 中止

javascript - AngularJS : Scope value changing, 但并不总是应用 ng-class

javascript - $scope.$watch 函数未按预期触发 nodelist.length 更改