0
Plnkr样本:http://plnkr.co/edit/jlMQ66eBlzaNSd9ZqJ4m?p=preview][1]角动态创建的指令不执行
这可能不是正确的“角”的方式来做到这一点,但不幸的是,我与我有限的能力改变一些第三方库工作。我试图动态创建一个角度指令并将其添加到页面。该过程至少在指令元素被添加到DOM的意义上说起作用,然而它并没有被实际执行 - 在这一点上它只是一个愚蠢的DOM。
相关的代码如下:
<div ng-app="myModule">
<div dr-test="Static Test Works"></div>
<div id="holder"></div>
<a href="#" onclick="addDirective('Dynamic test works')">Add Directive</a>
</div>
var myModule = angular.module('myModule', []);
myModule.directive('drTest', function() {
console.log("Directive factory was executed");
return {
restrict: 'A',
replace: true,
link: function postLink(scope, element, attrs) {
console.log("Directive was linked");
$(element).html(attrs.drTest);
}
}
});
function addDirective(text){
console.log("Dynamically adding directive");
angular.injector(['ng']).invoke(['$compile', '$rootScope',function(compile, rootScope){
var scope = rootScope.$new();
var result = compile("<div dr-test='"+text+"'></div>")(scope);
scope.$digest();
angular.element(document.getElementById("holder")).append(result);
}]);
}
</script>
完美!我知道我错过了一些东西(回想起来)。 Thaks – 2014-09-19 02:45:17
@JohnP不客气 – PSL 2014-09-19 02:46:36