2015-06-15 64 views
0

我有以下模板的自定義指令。AngularJS我的自定義指令不能訪問屬性,但它似乎其他自定義指令可以

.directive('myDirective', ['$controller',function($controller) { 
     return { 
      templateUrl: 'client/test.ng.html', 
      scope: true, 
      controller: ['$scope','$attrs',function($scope,$attrs){ 
       console.log($attrs) 
      }], 
      transclude: true, 

     } 
    }]) 

這個指令是被稱爲如下

<my-directive view="{{view}}"></my-directive> 
    <ion-tab ng-if="platform != 'android'" title="{{label}}" icon-off="{{off}}" icon-on="{{on}}" href="#/tab/{{view}}"> 
      <my-directive view="{{view}}"></my-directive> 
    </ion-tab> 

    <ion-tab ng-if="platform == 'android'" title="{{label}}" class="tab-item" href="#/tab/{{view}}"> 
      <my-directive view="{{view}}"></my-directive> 
    </ion-tab> 

$attrs.view{{view}},uninterpolated。 <ion-tab>將表達式內插到變量值中,顯示正確的數據。

這對我來說很困惑。我已經在ion-tab指令的內部和外部放置了my-directive,以防出現某種範圍問題。

訪問表達式的值並使用該值反過來調用另一個指令的關鍵是什麼?


背景:

我經歷這一切的原因是因爲

<ion-nav-view name="tab-{{view}}"></ion-nav-view>不起作用。它,就像my-directive似乎無法獲得```view`的值,而是原始未解析的請求。我試圖獲取該值並直接調用該指令。

我似乎可以用$ scope獲得我想要的值$ parent.view然後神祕地設置$ scope.view = $ scope。$ parent.view並設置子模板中的{{view}} DOESNT工作!?


更多的洞察力,執行console.log($ ATTRS)給出:

$…t.Attributes {$attr: Object, $$element: jQuery.fn.init[1], view: "{{view}}", class: "pane tab-content", navView: "active"} 

然而,當這個被擴大,我們有

$$element: jQuery.fn.init[1] 
    $$observers: Object 
    $attr: Object 
    class: "pane tab-content" 
    navView: "active" 
    view: "dash" 
    __proto__: Object 

任何幫助表示讚賞,感謝。

+0

你可以請分享「查看」值獲取的腳本嗎?這個腳本看起來很好。 $ scope。$ parent.view是工作的,因爲你在定義你的指令時設置了scope:true。因此,該指令原型繼承了父範圍 –

+0

@RIYAJKHAN當然,這裏是一個相關的問題更詳細w/plunker鏈接:http://stackoverflow.com/questions/30854373/angularjs-cannot-interpolate-attribute-from-第一個指令到第二個w-pl – Babak

+0

我已更新http://stackoverflow.com/questions/30854373/angularjs-cannot-interpolate-attribute-from-first-directive-to-a-second-w -pl/30859861#30859861。這裏是最後一個小提琴.http://plnkr.co/edit/WoglpCyQmg9WYs5MrKYw?p = preview –

回答

0

使用鏈接功能獲取屬性值。

.directive('myDirective', ['$controller',function($controller) { 
    return { 
     templateUrl: 'client/test.ng.html', 
     scope: true, 
     transclude: true, 
     link: function(scope,element,attrs){ 
      console.log(attrs); 
     } 
    } 
}]) 
+0

感謝你。經過一番挖掘,似乎模板函數在鏈接(前後)之前被調用,所以我不知道如何影響模板的渲染,因爲它已經被評估。 – Babak

0

我上無法看到你的指令內的任何HTML,所以我刪除transclude:真

.directive('myDirective', function() { 
    return { 
     templateUrl: 'client/test.ng.html', 
     scope: { 
      view: '=' 
     }, 
     link: function (scope) { 
      console.log("view", view); 
      scope.$watch("view", function (newView, prevView) { 
       console.log("changed view", scope.view, newView, prevView); 
      }); 
     } 
    } 
}) 
0

這是一個計時問題當某些事情發生一個指令的生命週期內是有關以及它經歷的幾個階段。 在儘可能少detaila越好,這些是相:

  1. 編譯
  2. 實例化控制器
  3. 預聯
  4. 後聯

注意resovling內插屬性( {{...}})的值在預鏈接階段有時會發生(並且它也是一個Angular內置指令)。這意味着:

a。在控制器實例化期間解決的值是而不是。 b。這些值在鏈接後階段當然是可以解決的。
c。根據您的指令相對於(深奧)屬性插值指令(其優先級高於100)的相對優先級,在預鏈接階段可能會或可能不會解決這些值。

注意:更高的優先級意味着更早的鏈接正在發生。


docs on $compile做一個公平的工作,解釋正在發生的事情(如果你仔細閱讀它真的)。

+0

感謝您分享此洞見。 – Babak

+0

如果在預鏈接之前調用模板函數,那麼預鏈接函數如何將數據注入到模板中? – Babak

+0

我重新考慮了這個問題,並且包含了一個plunker演示,以防您可能會好奇地幫助http://stackoverflow.com/questions/30854373/angularjs-cannot-interpolate-attribute-from-first-directive-to-a- second -w-pl – Babak