Ich möchte ein Formular mit Daten anzeigen, die dem bearbeiteten Element entsprechen. Ich verwende ui-router
für das Routing. I definiert einen Zustand:Angular-UI-Router erhalten asynchrone Daten mit Auflösung
myapp.config(function($stateProvider) {
$stateProvider.
.state('layout.propertyedit', {
url: "/properties/:propertyId",
views : {
"[email protected]": {
templateUrl : 'partials/content2.html',
controller: 'PropertyController'
}
}
});
In PropertyController
, ich möchte setzen $scope.property
mit Daten aus dem folgenden Aufruf kommen (Google Cloud Endpoints):
gapi.client.realestate.get(propertyId).execute(function(resp) {
console.log(resp);
});
Ich weiß nicht, ob ich resolve
verwenden können weil die Daten asynchron zurückgegeben werden. Ich habe versucht,
resolve: {
propertyData: function() {
return gapi.client.realestate.get(propertyId).execute(function(resp) {
console.log(resp);
});
}
}
Erste Ausgabe, die propertyId
nicht definiert ist. Wie bekommen Sie die propertyId
von der url: "/properties/:propertyId"
?
Grundsätzlich möchte ich $scope.property
in PropertyController
auf die resp
Objekt vom Async-Aufruf zurückgegeben werden.
EDIT:
myapp.controller('PropertyController', function($scope, , $stateParams, $q) {
$scope.property = {};
$scope.create = function(property) {
}
$scope.update = function(property) {
}
function loadData() {
var deferred = $q.defer();
gapi.client.realestate.get({'id': '11'}).execute(function(resp) {
deferred.resolve(resp);
});
$scope.property = deferred.promise;
}
});
Füge bitte eine JSFiddle hinzu. – zsong