我一直在学习/研究一个新手项目,该项目基本上是一个简单的任务管理器(类似于那些待办事项列表项目)。我为此项目设计了一个用户登录页面,这是它的工作方式。
因此,我有两个函数siteLogin()
用于登录并在其中登录,我想在用户登录后使用第二个函数showTasks()
,该函数返回从API获得的用户任务(我知道的承诺< / strong>)。
因此,首先我需要从showTasks()
函数内的 $ http 返回一个值,但最终返回了类似$$state
的内容,因此我搜索并找到了几种解决方案在该网站上,到目前为止,我了解到 $ http 不会返回值,但会返回承诺。因此,在几次尝试失败之后,我的代码现在可以运行到showTasks()
并在那里停止。
这是我的代码。
工厂
app.factory('userTaskList', function ($http) {
return {
showTasks: function (userName) {
var tasks = { K_ADI: userName }; //UserName of the per
var $promise = $http({
method: 'POST',
url: 'http://localhost:5169/api/Isler/' + userName + '/IstenilenKayitCek',
headers: {
'Content-Type': 'application/json'
},
data: tasks
});
$promise.then(function successCallback(response) {
var data = response.data;
console.log("Factory data:", response);
return success(data);
}, function errorCallback(response) {
error("Error");
});
}
}
});
还有我的控制器:
app.controller('myCtrl', ['$scope', '$http', function ($scope, $http,userTaskList ) {
$scope.siteLogin = function () {
var loginMember = {
K_ADI: $scope.panel.loginUserName,
PAROLA: $scope.panel.loginPassword // HTML input
};
console.log(loginMember);
$http({
method: 'POST',
url: 'http://localhost:5169/api/Kullanicilar/KullaniciDogrula',
headers: {
'Content-Type': 'application/json'
},
data: loginMember
}).then(function successCallback(response) {
console.log("Message sent", response);
$scope.data = response.data.error.data;
if ($scope.data === true) {
console.log("User exists in database");
//RUNS UNTIL HERE AND STOPS
userTaskList.showTasks($scope.panel.loginUserName)
.then(function (res) {
$scope.gorev = res;
console.log("Fonk ici : ", $scope.gorev);
console.log("222222", res);
}, function (err) {
console.log(err);
});
console.log("outside func : ", $scope.gorev);
}
}, function errorCallback(response) {
console.log("Error: ", response);
});
}
}]);
这可能看起来像重复的,并且在堆栈上有许多类似的问题,但是我尝试了这些解决方案(我将在以后进行链接)仍然没有解决我的问题,而且其中一些还会产生其他类似的问题。我尝试使用$q
,嵌套.then
,最后在工厂定义代码,然后在模块中调用其实例,依此类推。但仍然无法正常工作。
注意:对不起,我英语不好。
答案 0 :(得分:2)
showTasks
函数中存在几个错误:
app.factory('userTaskList', function ($http) {
return {
showTasks: function (userName) {
var tasks = { K_ADI: userName }; //UserName of the per
var $promise = $http({
method: 'POST',
url: 'http://localhost:5169/api/Isler/' + userName + '/IstenilenKayitCek',
headers: {
'Content-Type': 'application/json'
},
data: tasks
});
var derivedPromise = $promise.then(function successCallback(response) {
var data = response.data;
console.log("Factory data:", response);
̶r̶e̶t̶u̶r̶n̶ ̶s̶u̶c̶c̶e̶s̶s̶(̶d̶a̶t̶a̶)̶;̶
//IMPORTANT
return data;
}, function errorCallback(response) {
̶e̶r̶r̶o̶r̶(̶"̶E̶r̶r̶o̶r̶"̶)̶;̶
console.log(response.status);
//IMPORTANT
throw response;
});
//IMPORTANT
return derivedPromise;
}
}
});
所需的数据需要返回到.then
方法成功处理程序中。
错误处理程序中的错误需要重新抛出。否则,被拒绝的承诺将被转换为成功,其值为undefined
。
最后,派生的Promise必须返回到showTasks
函数。
您认为我在
$scope.siteLogin
内部正确调用了该函数吗?
依赖注入是错误的:
̶a̶p̶p̶.̶c̶o̶n̶t̶r̶o̶l̶l̶e̶r̶(̶'̶m̶y̶C̶t̶r̶l̶'̶,̶ ̶[̶'̶$̶s̶c̶o̶p̶e̶'̶,̶ ̶'̶$̶h̶t̶t̶p̶'̶,̶ ̶
function ($scope, $http,userTaskList ) {
app.controller('myCtrl', ['$scope', '$http', 'userTaskList',
function ($scope, $http,userTaskList ) {
app.controller('myCtrl', function ($scope, $http,userTaskList ) {