我定义了一个工厂来进行解析调用,该调用在完成时解析。
.factory('currentRestaurantService', ['$rootScope', '$q', function($scope, $q) {
return {
getCurrentRestaurant: function() {
var defer = $q.defer(); // Create a deferring object
$scope.currentUser = Parse.User.current();
// Get restaurant for user
var restaurantObject = Parse.Object.extend("Restaurant");
var query = new Parse.Query(restaurantObject);
var thisUsersRestaurants = query.equalTo("user", $scope.currentUser);
thisUsersRestaurants.find().then(function(restaurants) {
defer.resolve($scope.restaurants);
});
return defer.promise; // Create an Angular promise to be resolved
}
};
}])
在进入销售页面之前,我希望在一个州中的一个resolve块中进行呼叫,以进行解决。
.state('dashboard.sales', {
url: '/sales',
templateUrl: './app/dashboard/partials/sales/sales.html',
controller: 'DashboardSalesCtrl',
resolve: {
currentRestaurant: function() { return currentRestaurantService.getCurrentRestaurant(); }
}
})
我不知道为什么这行不通。在过去的一周里,我一直在撞墙,无法弄清楚。我的代码有什么问题?
您应该先注入currentRestaurantService
依赖项,然后才能在resolvecurrentRestaurant
函数中使用它。
代码
.state('dashboard.sales', {
url: '/sales',
templateUrl: './app/dashboard/partials/sales/sales.html',
controller: 'DashboardSalesCtrl',
resolve: {
currentRestaurant: function(currentRestaurantService) { //added dependency in function
return currentRestaurantService.getCurrentRestaurant();
}
}
})
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句