ng-if 下的指令在 DOM 中插入时不会重新编译
Directive under ng-if doesn't get recompiled when inserted in DOM
这是一个演示标题中描述的问题的示例:https://plnkr.co/edit/Xn1qgYftc5YHMsrGj0sh?p=preview
指令代码:
.directive('translate', function($compile) {
return {
compile: function(element) {
var html = element.html().split('<br plural="">');
return function(scope, element, attrs) {
function c(h) {
element.html(h);
$compile(element.contents())(scope);
}
if (attrs.translate != '') {
scope.$watch(function() {
return scope.$eval(attrs.translate)
}, function(val, oldval) {
if (val == oldval && html[2] !== undefined) return;
var p = html[2];
html[2] = gettext(html[0], html[1], attrs.add !== undefined ? val + attrs.add : attrs.subtract !== undefined ? val - attrs.subtract : val);
if (p != html[2]) c(html[2]);
});
} else c(gettext(html[0]));
}
}
}
})
所以问题是当我切换回指令以使用 ng-if
显示时 - 它可能不会通过重新编译(?)完全重置,因此会导致错误行为。
如何跟踪指令何时从 DOM 插入和删除?如果有办法,我可以用一个指标来解决这个问题。但一定有更好的方法吧?
这样解决的:
.directive('translate', function($compile) {
return {
compile: function(element, attrs) {
if (attrs.translate == '') {
element.html(gettext(element.html()));
return;
}
attrs.html = element.html().split('<br plural="">');
return {
post: function (scope, element, attrs) {
delete attrs.html[2];
scope.$watch(function () {
return scope.$eval(attrs.translate);
}, function (val) {
var p = attrs.html[2];
attrs.html[2] = gettext(attrs.html[0], attrs.html[1], attrs.add !== undefined ? val + attrs.add : attrs.subtract !== undefined ? val - attrs.subtract : val);
if (p == attrs.html[2]) return;
element.html(attrs.html[2]);
$compile(element.contents())(scope);
});
}
}
}
}
})
我认为我已经优化得够好了,但请随时更正代码。
这是一个演示标题中描述的问题的示例:https://plnkr.co/edit/Xn1qgYftc5YHMsrGj0sh?p=preview
指令代码:
.directive('translate', function($compile) {
return {
compile: function(element) {
var html = element.html().split('<br plural="">');
return function(scope, element, attrs) {
function c(h) {
element.html(h);
$compile(element.contents())(scope);
}
if (attrs.translate != '') {
scope.$watch(function() {
return scope.$eval(attrs.translate)
}, function(val, oldval) {
if (val == oldval && html[2] !== undefined) return;
var p = html[2];
html[2] = gettext(html[0], html[1], attrs.add !== undefined ? val + attrs.add : attrs.subtract !== undefined ? val - attrs.subtract : val);
if (p != html[2]) c(html[2]);
});
} else c(gettext(html[0]));
}
}
}
})
所以问题是当我切换回指令以使用 ng-if
显示时 - 它可能不会通过重新编译(?)完全重置,因此会导致错误行为。
如何跟踪指令何时从 DOM 插入和删除?如果有办法,我可以用一个指标来解决这个问题。但一定有更好的方法吧?
这样解决的:
.directive('translate', function($compile) {
return {
compile: function(element, attrs) {
if (attrs.translate == '') {
element.html(gettext(element.html()));
return;
}
attrs.html = element.html().split('<br plural="">');
return {
post: function (scope, element, attrs) {
delete attrs.html[2];
scope.$watch(function () {
return scope.$eval(attrs.translate);
}, function (val) {
var p = attrs.html[2];
attrs.html[2] = gettext(attrs.html[0], attrs.html[1], attrs.add !== undefined ? val + attrs.add : attrs.subtract !== undefined ? val - attrs.subtract : val);
if (p == attrs.html[2]) return;
element.html(attrs.html[2]);
$compile(element.contents())(scope);
});
}
}
}
}
})
我认为我已经优化得够好了,但请随时更正代码。