A $ orologio è necessario qui, perché è tutto asincrono non possiamo contare sui tempi:
myApp.controller('navCtrl', ['$state', '$scope','$timeout', function($state, $scope, $timeout){
$scope.currState = $state;
console.log("This one have some objects: ");
console.log('by reference:', $scope.currState);
console.log('by value:', JSON.parse(JSON.stringify($scope.currState)));
// console.log("But when I want to access name its empty: ");
// $timeout(function() {
// console.log($state.current.name);
// });
// use this instead:
$scope.$watch('currState.current.name', function(newValue, oldValue) {
console.log(newValue);
});
}]);
Il console.log('by reference:', $scope.currState);
funziona perché che utilizza un riferimento all'oggetto. Quando lo vediamo nella console, l'oggetto è già cambiato.
Confrontare con l'uscita di console.log('by value:', JSON.parse(JSON.stringify($scope.currState)));
precedente, che blocca l'uscita nel punto di esecuzione. Troverete uno $state.current.name
vuoto.
Vedi anche: How can I change the default behavior of console.log? (*Error console in safari, no add-on*)
Mi dispiace "Inserire il codice qui" Io missclicked e ora non riesco a modificare il mio post. – Arth
Nel plunker lancia l'anteprima in una finestra separata, e funziona come un incantesimo. :) –
@Arth qual è il problema, posso vedere '$ state.current.name' nella console? –