如何将 $stateParams 从 ui-router 传递给 resolve 服务?
How to pass $stateParams from ui-router to service in resolve?
我有一个检索单个 post 的路径和一个查询我的 API 的服务。但我需要将参数从 URL 传递给服务,以便我可以正确调用 API。我不知道该怎么做。
这是我到目前为止的想法。我遗漏了与这个问题无关的内容。
感谢您的帮助!
路由
myModule.config([
'$stateProvider',
'$urlRouterProvider',
'$locationProvider',
function($stateProvider, $urlRouterProvider, $locationProvider) {
$stateProvider
.state('post', {
url: '/posts/:hash_id/:slug',
templateUrl: '/js/app/views/post.html',
controller: 'PostCtrl',
resolve: {
postPromise: ['posts', function(posts, $stateParams){
//returns undefined
console.log($stateParams);
return posts.getOne($stateParams);
}]
}
})
// etc
服务
myModule.factory('posts', ['$http', 'auth', function($http, auth){
var o = {
posts: [],
post: {}
};
o.getOne = function(params) {
// Returns undefined
console.log(params);
return $http.get('/api/v1/posts/' + params.hash_id).success(function(data){
angular.copy(data, o.post);
});
};
return o;
}])
您错过了在 postPromise
resolve
中添加 $stateParams
依赖项
代码
postPromise: ['posts', '$stateParams', function(posts, $stateParams){
我有一个检索单个 post 的路径和一个查询我的 API 的服务。但我需要将参数从 URL 传递给服务,以便我可以正确调用 API。我不知道该怎么做。
这是我到目前为止的想法。我遗漏了与这个问题无关的内容。
感谢您的帮助!
路由
myModule.config([
'$stateProvider',
'$urlRouterProvider',
'$locationProvider',
function($stateProvider, $urlRouterProvider, $locationProvider) {
$stateProvider
.state('post', {
url: '/posts/:hash_id/:slug',
templateUrl: '/js/app/views/post.html',
controller: 'PostCtrl',
resolve: {
postPromise: ['posts', function(posts, $stateParams){
//returns undefined
console.log($stateParams);
return posts.getOne($stateParams);
}]
}
})
// etc
服务
myModule.factory('posts', ['$http', 'auth', function($http, auth){
var o = {
posts: [],
post: {}
};
o.getOne = function(params) {
// Returns undefined
console.log(params);
return $http.get('/api/v1/posts/' + params.hash_id).success(function(data){
angular.copy(data, o.post);
});
};
return o;
}])
您错过了在 postPromise
resolve
$stateParams
依赖项
代码
postPromise: ['posts', '$stateParams', function(posts, $stateParams){