2014-01-19 79 views
16

編譯HTML就有了下面的方式在AngularJS動態添加HTML

var template = '<div>{{value}}</div>'; 
    var element = angular.element(template); 
    placeholder.replaceWith(element); 
    $compile(element)($scope); 

是否有可能從templateURL單獨做相同或負載模板? (使用標準機制,以便將其緩存在$ templateCache中)

回答

22

當然,您只需使用$http服務來獲取模板,而不是手動編譯和插入它。 $http服務將隱式地處理緩存。

PLUNKER

(最簡單的)指令:

app.directive('message', [ 
    '$http', 
    '$compile', 
    function($http, $compile) { 
    var tpl = "template.html"; 

    return { 
     scope: true, 
     link: function(scope, element, attrs){ 
     scope.message = attrs.message; 

     $http.get(tpl) 
      .then(function(response){ 
      element.html($compile(response.data)(scope)); 
      }); 
     } 
    }; 

    } 
]); 

查看:

<span message="Hi World!"></span> 
<span message="My name is Angular."></span> 

指令模板(template.html):

<span>{{message}}</span> 
+0

此外,如果您使用$ templateCache服務來緩存模板會更好。 – Nilesh

+2

要自動處理所有這些細節($ templateCache),只需使用$ templateRequest。 – Interarticle

+0

謝謝,在我使用'$ rootScope'之前,它真的很慢。現在修好了。 – Miao1007