Angularjs Angular-返回未定义值的工厂http post
我搜索和研究,但我不能解决我的问题 我不太会练习,希望有人能帮我 我为HTTPPOST创建了一个服务,我必须从我的控制器获得结果 控制器Angularjs Angular-返回未定义值的工厂http post,angularjs,http,post,Angularjs,Http,Post,我搜索和研究,但我不能解决我的问题 我不太会练习,希望有人能帮我 我为HTTPPOST创建了一个服务,我必须从我的控制器获得结果 控制器 tantoSvagoApp.controller("ricercaAttivita", function ($scope, serviceRegioni, serviceRicercaAttivita) { $scope.regioni = serviceRegioni.get(); var parameters = { "
tantoSvagoApp.controller("ricercaAttivita", function ($scope,
serviceRegioni, serviceRicercaAttivita) {
$scope.regioni = serviceRegioni.get();
var parameters = {
"MasterID": 14,
"NumPart": "",
"Text": "",
"Location": {"Region": "", "Province": ""},
"Attributes": [],
"Price": {"MinPrice": "","MaxPrice": ""},
"ProjectCode": "WS678",
"Pager": {"PageSize": 10,"PageOffset": 1}
};
$scope.elencoAttivita = serviceRicercaAttivita.getAttivita(parameters);
});
服务
tantoSvagoApp.service('serviceRicercaAttivita', function ($http) {
this.getAttivita = function(arr) {
$http({
method: 'POST',
url: 'http://localhost/Tantosvago/api/getAttivita.php',
data: arr
}).then(function successCallback(response) {
var result = response.data;
return result;
}, function (response) {
console.log("Errore " + response.data,response.status);
});
};
}
);
未定义。对
$http.post()
的成功和失败回调是不能返回任何值的异步方法
解决方案如下所示
控制器
tantoSvagoApp.controller("ricercaAttivita", function ($scope,
serviceRegioni, serviceRicercaAttivita) {
$scope.regioni = serviceRegioni.get();
var parameters = {
"MasterID": 14,
"NumPart": "",
"Text": "",
"Location": {"Region": "", "Province": ""},
"Attributes": [],
"Price": {"MinPrice": "","MaxPrice": ""},
"ProjectCode": "WS678",
"Pager": {"PageSize": 10,"PageOffset": 1}
};
function successCallBack(result) {
$scope.elencoAttivita = result;
}
serviceRicercaAttivita.getAttivita(parameters, successCallBack);
});
服务
tantoSvagoApp.service('serviceRicercaAttivita', function ($http) {
this.getAttivita = function(arr, successCallBack) {
$http({
method: 'POST',
url: 'http://localhost/Tantosvago/api/getAttivita.php',
data: arr
}).then(function successCallback(response) {
successCallBack(response.data);
}, function (response) {
console.log("Errore " + response.data,response.status);
});
};
});
$http是异步运行的,因此当您调用代码时,只需进行调用并继续; 您可以通过在getAttivita函数中放入return语句来检查它,如下所示:
this.getAttivita = function(arr) {
$http({
method: 'POST',
url: 'http://localhost/Tantosvago/api/getAttivita.php',
data: arr
}).then(function successCallback(response) {
var result = response.data;
return result;
}, function (response) {
console.log("Errore " + response.data,response.status);
});
};
return "Test";
}
要执行所需操作,需要将回调函数传递给tour函数,并在此回调函数中将值分配给$scope porperty:
在控制器中:
function Callback(elencoAttivita) {
$scope.elencoAttivita = elencoAttivita;
}
serviceRicercaAttivita.getAttivita(parameters, Callback);
为您服务:
this.getAttivita = function(arr, Callback) {
$http({
method: 'POST',
url: 'http://localhost/Tantosvago/api/getAttivita.php',
data: arr
}).then(function successCallback(response) {
var result = response.data;
Callback(result);
}, function (response) {
console.log("Errore " + response.data,response.status);
});
};
}