Pada dasarnya ini adalah solusi yang akhirnya saya gunakan.
$ apply () hanya boleh digunakan oleh sumber eksternal dalam situasi yang tepat.
daripada menggunakan apply, saya telah melempar pembaruan lingkup ke akhir tumpukan panggilan. Berfungsi sebaik "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);
});
}
};
}]);