Basicamente, essa é a solução que acabei usando.
$ apply () só deve ser usado por fontes externas nas circunstâncias certas.
em vez de usar apply, lancei a atualização de escopo para o final da pilha de chamadas. Funciona tão bem quanto "scope. $ 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);
});
}
};
}]);