В основному це рішення, яке я закінчив використовувати.
$ apply () слід використовувати лише зовнішніми джерелами за правильних обставин.
замість цього, використовуючи Apply, я кинув оновлення сфери на кінець стека викликів. Працює так само добре, як "область. $ Apply (attrs.imageonload) (true);".
window.app.directive("onImageload", ["$timeout", function($timeout) {
function timeOut(value, scope) {
$timeout(function() {
scope.imageLoaded = value;
});
}
return {
restrict: 'A',
link: function(scope, element, attrs) {
element.bind('load', function() {
timeOut(true, scope);
}).bind('error', function() {
timeOut(false, scope);
});
}
};
}]);