2016-04-06 13 views
0

私は角-outsideロードしようとしていますがロードされていない動的カスタムディレクティブ が、カスタムディレクティブは、私は次のように$compile を使用しているにもかかわらず、ロードされていないカスタムディレクティブが正しく

app.directive('mydirective',function(){ 
    return { 
    template: '<div>Succeeded !</div>', 
    } 
}) 

と、ここで私は動的に指示をロードしています場所:

function showresultcust() { 
angular.injector(['ng']).invoke(['$compile', 
    function ($compile) { 
     var scope = angular.element(document.getElementById("test1")).scope(); 
     var _html = '<div>{{name}}-</div><div mydirective >Not Succeed</div>'; 
     //var _html='<div >{{loaded}}</div>'; 
     var obj = $('#content'); 
     $('#content').html($compile(_html)(scope)); 
     // compile!!! 
     $compile(obj.contents())(scope); 
     scope.$digest(); 
     setTimeout(function() { 
      scope.$apply(); 
     }); 
    } 
]); 
} 

ダイナミックHTMLで{{name}}が正しいロードされていることに注意してくださいカスタムディレクティブではありません。 完全なデモはthis 'plnkr.co' link

上記の 'plnkr'リンクで直接修正できたら、私はそれを感謝します。

答えて

0

mydirectiveディレクティブがngモジュールの一部ではないため、このコードではコードがコンパイルされていません。ディレクティブを含むモジュールを新しいインジェクタの依存関係リストに追加します。

//NOT this 
//angular.injector(['ng']).invoke(['$compile', 

//Do this 
angular.injector(['ng','tumblr']).invoke(['$compile', 
    function ($compile) { 
     var scope = angular.element(document.getElementById("test1")).scope(); 
     var _html='<div>{{name}}-</div><div mydirective >Not Succeed</div>'; 
     $('#content').html($compile(_html)(scope)); 
     scope.$apply(); 
    } 
]); 
} 

angular.injector関数は常に新しい注射器を作成し、それが依存関係リスト内の全ての依存関係を必要とします。

+0

これは機能します!ありがとう@georgeawg私はちょうど実際の名前のプランナーにtumblrを変更しました – Nahed

+0

もう一度質問してください。私はtemplateUrlを使用すると、それは{{name}}を表示しているテンプレートを再度翻訳していません。ここではtemplateUrlを使用しています。http://plnkr.co/edit/L82o3zVbM5p76Kyfp8WE?p=preview – Nahed

+0

私の例ではコンパイルと適用が簡略化されています。あなたのplnkrには2つの '$ compile'と生の' setTimeout'があります。すべてのものは不要です。 – georgeawg