angular.js - angularjs如何中,controller如何获取factory返回的值呢?
世界只因有你
世界只因有你 2017-05-15 17:00:43
0
1
633
var app = angular.module("MyApp", []);

app.factory("myFactory", function ($http) {

    return {
        
        getDatas: function () {

            var args = {};
            var url = "test.req";

            $http({
                method: 'POST',
                data: args,
                url: url
            }).success(function (response, status, headers, config) {

                return response;


            }).error(function (response, status, headers, config) {

                alert(status + response);

            });

        }

    };

});

app.controller("myCtrl", function ($scope, myFactory) {

    $scope.names = {};
    $scope.title = myFactory.msg;

    alert(myFactory.getDatas());
    $scope.names = myFactory.getDatas();

});

以上代码中alert(myFactory.getDatas());
获取不到factory的值的,显示undefined。
浏览器debug显示:
angular1.5.3.min.js:6Uncaught Error: [$injector:modulerr]

factory能够从后端获取到数据,就是controller这头不知道怎么互获取factory的数据.....

世界只因有你
世界只因有你

Antworte allen(1)
黄舟

最近才开始看angular……


你看getDatas方法里面实际上是一个异步函数执行体,getDatas一执行,然后$http就去异步请求后端数据了,但getDatas执行完了,就return了 ,alert拿不到值咯。

app.factory("myFactory", function ($http) {
    return {
        getDatas:function(){
             return $http.get('data/data.json');//return 一个promise
        }
    }

});

app.controller("myCtrl", function ($scope, myFactory) {

    $scope.names = {};
    $scope.title = myFactory.msg;

    //alert(myFactory.getDatas());
    myFactory.getDatas().success(function (response, status, headers, config) {
                        //要用到返回数据就在这里用了
                        console.log(response);
                        


                    }).error(function (response, status, headers, config) {

                        alert(status + response);

                    });
   //下面这句看起来像是要获取数据,挪到上面的success去  $scope.xxx=
    $scope.names = myFactory.getDatas();

});
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage