我有一个递归的Ng-include导致错误:$ rootScope:infdig Infinite $ digest Loop
在我的ctrl:
function getTemplate(elementType) {
console.log(elementType + '_formElement.html');
return elementType + '_formElement.html';
};
在我看来:
<div ng-repeat="element in elementList track by $index" ng-init="templateID=vm.getTemplate(element.elementType)">
<ng-include src="templateID"></ng-include>
</div>
结果:达到10 $ digest()迭代次数。中止!
观察者在最后5次迭代中被解雇:[[{“msg”:“fn:function (C,E,F,G){F = d&安培;&安培; G G [0]:一个(C,E,F,G);返回 b(f,c,e)}“,”newVal“:3},{”msg“:”fn:function(a){return d(A)} “ ”的newval“: ”“},{ ”msg“ 中: ”templateID“, ”的newval“: ”ROW_formElement.html“}],[{ ”msg“ 中:” FN: 函数(c,e,f,g){f = d&amp;&amp; g?g [0]:a(c,e,f,g); return b(f,c,e)}“,”newVal“:3},{”msg“:”fn:function(a){return d(A)} “ ”的newval“: ”“},{ ”msg“ 中: ”templateID“, ”的newval“: ”ROW_formElement.html“}],[{ ”msg“ 中:” FN: 函数(c,e,f,g){f = d&amp;&amp; g?g [0]:a(c,e,f,g); return b(f,c,e)}“,”newVal“:3},{”msg“:”fn:function(a){return d(A)} “ ”的newval“: ”“},{ ”msg“ 中: ”templateID“, ”的newval“: ”ROW_formElement.html“}],[{ ”msg“ 中:” FN: 函数(c,e,f,g){f = d&amp;&amp; g?g [0]:a(c,e,f,g); return b(f,c,e)}“,”newVal“:3},{”msg“:”fn:function(a){return d(A)}”, “的newval”: “”},{ “msg” 中: “templateID”, “的newval”: “FIELD_formElement.html”}],[{ “msg” 中: “templateID”, “的newval”: “TEXT_field.html”},{ “味精”:“FN: function(a){return d(a)}“,”newVal“:”“}]]
CONSOLE.LOG:
ROW_formElement.html
7 ROW_formElement.html
FIELD_formElement.html
我知道我可以像以下那样增加TTL,但还有其他解决方案吗?
angular.module('myApp',[])
.config(function($rootScopeProvider) {
$rootScopeProvider.digestTtl(number); //some number bigger then 10
})