我實際上試圖從用戶點擊列表中包含一些指令。AngularJs從列表中動態創建指令
這裏的名單:
$scope.listModules = [
{libelle: "Utilisateurs connectés", template: "<div class='user-connecte'></div>", drag: true},
{libelle: "utilisateur temps de passe en zone", template: "<div class='user-graph-temps-attente'></div>", drag: true},
{libelle: "Nombre d'anomalies", template: "<div class='nombre-anomalie'></div>", drag: true},
{libelle: "Tableau de prestations", template: "<div class='prestation-tableau'></div>"},
{libelle: "Graph de prestations camembert", template: "<div class='prestation-graph-camembert'></div>", drag: true},
{libelle: "Tableau de traitements", template: "<div class='traitement-tableau'></div>", drag: true},
{libelle: "Graph de traitement à granularité", template: "<div class='traitement-graph-granularity'></div>", drag: true}
];
我在NG-重複列表中顯示它,我不能用簡單:
NG綁定,HTML或NG綁定,HTML的不安全
實際上,它們在DOM中顯示HTML標籤,但內容未加載。
下面是關於我的應用程序的樣本指令:
angular.module('app')
.directive('userConnecte', function ($compile) {
return {
restrict: 'EAC',
templateUrl: 'tpl/directive/UserConnecteDirective.html'
};
});
注:如果我用我的指令列表外,它就像一個魅力。感謝提前
這裏的HTML內容:
<div class="col-md-4" style="height:380px;"
ng-repeat="currentModule in listeCurrentModule" data-drag="{{currentModule.drag}}"
data-jqyoui-options="{revert: 'invalid'}" ng-model="listeCurrentModule"
jqyoui-draggable="{index: {{$index}},animate:true}">
<div ng-bind-html="currentModule.template">
</div>
</div>
你能幫助我嗎?
編輯:
我試圖編譯的東西,但它似乎使用templateUrl有點不同:-o
這裏是我的新嘗試:
angular.module('app')
.directive('userConnecte', function ($compile) {
return {
restrict: 'EAC',
templateUrl: 'tpl/directive/UserConnecteDirective.html',
replace: true,
link: function (scope, ele, attrs) {
scope.$watch(attrs.userConnecte, function (html) {
ele.html(html);
$compile(ele.contents())(scope);
});
}
};
});
感謝提前
'內容未加載'您正在談論哪些內容? – bviale 2015-04-03 13:53:49
我的指令的templateUrl沒有加載到HTML中。實際上,我只看到
,但看不到他的內容 – mfrachet 2015-04-03 13:54:27我不確定我是否明白爲什麼「不能使用ng-bind-html」或「ng-bind-html-unsafe」?任何時候有人說不可能使用用於他們問題目的的內置函數,它通常意味着還有其他事情正在發生,他們沒有分享。 – Claies 2015-04-03 14:11:50