Ich habe ein Problem mit meinem Skript, das Daten aus der Datenbank in Teilen sammelt. Ich möchte Angular informieren, wenn das Herunterladen der Daten abgeschlossen ist, also habe ich $ watch verwendet. Leider funktioniert es nicht. Winkelaufrufe funktionieren am Anfang anstatt nach dem Laden der ÄnderungVollständiger Wert.
angular
.module('app')
.controller('tlmController', function($scope, $http) {
var vm = this;
var data = [];
vm.countTestLines = 0;
vm.loadingComplete = false;
$scope.$watch('vm.loadingComplete', function() {
console.log(data);
});
$http({
method: 'GET',
url: 'app/server/tt/count_testlines.php'
}).then(function successCallback(response) {
vm.countTestLines = parseInt(response.data.count);
downloadInParts(data, 0, vm.countTestLines);
}, function errorCallback(response) {
console.log('error');
});
var downloadInParts = function(data, offset, max) {
if(max < offset) {
vm.loadingComplete = true;
return;
}
$http({
method: 'GET',
url: 'app/server/tt/get_testlines.php',
params: { offset: offset }
}).then(function successCallback(response) {
data = data.concat(response.data);
downloadInParts(data, offset + 5, max);
}, function errorCallback(response) {
console.log('error');
});
}
});
Ich bin kein Angular Typ, aber haben Sie versucht, newValue und oldValue zu Listener Param in '$ watch' Methode übergeben? Und dann könntest du 'if (newValue! == oldValue)' checken und deine Änderungen bearbeiten. –
Wenn eine der folgenden Antworten Ihr Problem gelöst hat, können Sie eine davon als Antwort akzeptieren. – Danscho