AngularJS:控制器返回未定义的值

AngularJS : Undefined value returned in controller

本文关键字:未定义 返回 控制器 AngularJS      更新时间:2023-09-26

我正在使用angularJS构建一个访问http资源的工厂。我可以看到在请求附近本地返回的数据,但数据不在控制器中返回。这是我的工厂:

myNameSpace.factory('simpleFactory', function ($http) {
var factory = {};
var customers = [];
factory.getCustomers = function () {
    $http.jsonp('http://URL&callback=JSON_CALLBACK').success(function (data) {
        customers = data;
        return customers;
    })
}
return factory;

});

我的控制器是:

myNameSpace.controller('DetailsController', function ($scope, $http, simpleFactory) {
var cust = simpleFactory.getCustomers();
$scope.CustomerData = simpleFactory.getCustomers();
console.log(cust); //The value that is display here is undefined
});

$http调用是一个ajax异步调用,这意味着您需要通过回调发送结果。这可能有帮助:

这是工厂:

myNameSpace.factory('simpleFactory', function ($http) {
var factory = {};
factory.getCustomers = function (callback) {
    $http.jsonp('http://URL&callback=JSON_CALLBACK').success(callback);
}
return factory;
});

用法如下:

myNameSpace.controller('DetailsController', function ($scope, $http, simpleFactory) {
    simpleFactory.getTopOffenders(function(offenders) {
        $scope.topoffendersData = offenders;
    });
});