gpt4 book ai didi

javascript - AngularJS - 脚本在工厂函数中停止运行并返回 promise

转载 作者:行者123 更新时间:2023-11-30 14:30:13 25 4
gpt4 key购买 nike

我一直在学习/从事一个新手项目,它基本上是一个简单的任务管理器(类似于那些待办事项列表项目)。我为这个项目设计了一个用户登录页面,下面是它的工作原理。

所以我有两个函数siteLogin()为了登录和进入它,我想使用第二个功能 showTasks()用户登录后返回从 API 获取的用户任务(我知道的 promise )。

所以首先我需要从 showTasks() 中的 $http 返回一个值功能,但我最终返回类似 $$state 的内容所以我在这个网站上搜索并找到了几个解决方案,到目前为止我了解到 $http 不返回值但返回 promises。所以在几次尝试和失败之后,我的代码现在运行到 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");
});
}
}
});

还有我的 Controller :

 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 ,最后在工厂中定义代码,然后在模块中调用其实例,依此类推。但还是不行。

注意:抱歉我的英语不好。

最佳答案

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 方法成功处理程序。

错误处理程序中的错误需要重新抛出。否则,被拒绝的 promise 将被转换为具有未定义值的成功。

最后派生的promise需要返回给showTasks函数。


更新

Do you think I call the function correctly inside the $scope.siteLogin ?

依赖注入(inject)错误:

̶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 ) {

关于javascript - AngularJS - 脚本在工厂函数中停止运行并返回 promise,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51313285/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com