[英]creating a service in angularJS, using restangular promises
好的,这让我发疯了,基本上我想做的是创建服务来获取和评估用户功能,我正在使用WP REST API。 我使用restangular获取我的JSON数据。
在此阶段,我正在测试控制器本身中的功能,但是无论在何处进行测试,无论是在使用this.method的自定义服务中还是在控制器内部,无论是否使用$ scope,结果始终都是不确定的。 我知道我在函数内返回true或false时缺少了某些东西,或者在JS中对promise进行了根本不同的东西。 这是代码:
var current_user = parseInt(o2_i18n.user_id),
currentUserCapabilities,
capability;
$scope.currentUserCan = function(capability) {
if(current_user !== '0') {
wpAPIResource.one('users').get()
.then(function(allUsers){
for (var i = 0; i < allUsers.length; i++) {
if ( allUsers[i].id === current_user ) {
var currentUserCapabilities = allUsers[i].capabilities;
for(var prop in currentUserCapabilities){
if (capability === prop) {
//$log.log( prop );
return prop;
} else {
//$log.log( prop );
return false;
}
}
}
}
}, function(reason){
$log.error(reason);
});
} else {
//The user is not logged in, therefor no capabilities
return false;
}
};
$log.log($scope.currentUserCan('publish_posts'));
if ( $scope.currentUserCan('publish_posts') ) {
$log.log( 'Yes I Can!' );
} else {
$log.warn('No Can\'t Do!');
}
如果current_user !== '0'
则currentUserCan
函数不返回任何内容。 例如,您应该让它返回一个承诺(对于以下情况,您需要注入$q
服务)
$scope.currentUserCan = function(capability) {
if(current_user !== '0') {
// note the "return" here
return wpAPIResource.one('users').get().then(function(allUsers){
for (var i = 0; i < allUsers.length; i++) {
if ( allUsers[i].id === current_user ) {
var currentUserCapabilities = allUsers[i].capabilities;
for(var prop in currentUserCapabilities){
if (capability === prop) {
return prop;
}
}
}
}
return false;
}, function(reason){
$log.error(reason);
return $q.reject(reason); // you still want the promise to fail
});
} else {
return $q.resolve(false);
// this turns the static value into a promise so the API for this
// function is consistent
}
};
然后消耗这样的功能
$scope.currentUserCan('publish_posts').then(function(can) {
if (can) {
$log.log('Yes I Can!');
} else {
$log.warn("No Can't Do!");
}
});
我还清理了一下您的循环。 在您的OP中,内部循环没有意义,如果在allUsers
数组中找不到该用户,则没有return
值。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.