新角度和堅持的東西,應該是很容易...AngularJS - 從工廠讀JSON,使用效果
我有幾個資源:
.factory('RSVPRes', function ($resource) {
return {
RSVP: $resource("../reservations/:id.json", {id:'@id'}, {'update': {method:'PUT'}, 'remove': {method: 'DELETE', headers: {'Content-Type': 'application/json'}}}),
Meals: $resource('../meals.json'),
UserInvites: $resource('../userinvite.json')
};
})
Meals.json:
[{"id":1,"name":"Chicken","description":"Chicken Yum!","created_at":"2013-12-11T22:37:28.994Z","updated_at":"2013-12-11T22:37:28.994Z","event_id":1,"event":{"name":"Wedding"}},{"id":2,"name":"Steak","description":"9oz","created_at":"2013-12-11T22:37:29.004Z","updated_at":"2013-12-11T22:37:29.004Z","event_id":2,"event":{"name":"Rehersal"}},{"id":3,"name":"Veggie","description":"Vegan","created_at":"2013-12-11T22:37:29.008Z","updated_at":"2013-12-11T22:37:29.008Z","event_id":3,"event":{"name":"Stag"}}]
UserInvites.json:
[{"id":18,"created_at":"2013-12-11T23:00:18.684Z","updated_at":"2013-12-11T23:00:18.684Z","event_id":1,"registry_id":1,"user_id":9,"total_in_party":2}]
數據似乎被格式化爲相同。這裏都很好。
在我的控制器
.controller('RSVPCtrl', function RSVPController($scope, RSVPRes, $state, $stateParams) {
//GET INVITATION(S)
RSVPRes.UserInvites.query().$promise.then(function(response){
$scope.invitation = response.data;
//BUILD SELECT LIST FOR MEALS
$scope.meals = RSVPRes.Meals.query();
//EDIT
if ($scope.rsvpId) {
$scope.rsvp = RSVPRes.RSVP.get({id: $scope.rsvpId}, function() {
// $scope.selectedUser = $scope.invite.user_id;
// $scope.selectedEvent = $scope.invite.event_id;
// $scope.selectedRegistry = $scope.invite.registry_id;
// $scope.selectedTotalInParty = $scope.invite.total_in_party;
});
}
//NEW
else {
//INITIALIZE EMPTY GUESTS
$scope.guests = [];
for (var i = 0; i < $scope.invitation.total_in_party; i++) {
$scope.guests[i] = {
first_name: '',
last_name: '',
meal: 1,
rsvp: 0
};
}
}
});
$scope.submit = function() {
for (var i = 0; i < $scope.guests.length; i++){
$scope.rsvp = new RSVPRes.RSVP();
$scope.rsvp.first_name = $scope.guests[i].first_name;
$scope.rsvp.last_name = $scope.guests[i].last_name;
$scope.rsvp.meal_id = $scope.guests[i].meal;
$scope.rsvp.rsvp = $scope.guests[i].rsvp;
$scope.rsvp.$save();
}
$state.transitionTo('rsvps');
};
})
EDITED現在檢查我的response.data我得到我的信息,但是我的$ scope.invitation仍然是不確定的...
任何幫助,非常感謝!
[角 - http.get返回undefined]的可能重複(http://stackoverflow.com/questions/20306717/angular-http-get-returning-undefined) – Stewie
@Stewie我已經更新了我的問題以反映變化,但仍然有一些麻煩,儘管... – OHope