Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/angularjs/25.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 使用JS工厂进行同步调用_Javascript_Angularjs_Angular Promise - Fatal编程技术网

Javascript 使用JS工厂进行同步调用

Javascript 使用JS工厂进行同步调用,javascript,angularjs,angular-promise,Javascript,Angularjs,Angular Promise,我正在尝试使用工厂模式进行同步呼叫 $scope.doLogin = function (username, password, rememberme) { appKeyService.makeCall().then(function (data) { // data = JSON.stringify(data); debugAlert("login controller app key service"+data);

我正在尝试使用工厂模式进行同步呼叫

$scope.doLogin = function (username, password, rememberme) {
        appKeyService.makeCall().then(function (data) {
//            data = JSON.stringify(data);
            debugAlert("login controller app key service"+data);
            var appkeyvalue = data.d.appkey;
            sessionConfigurationService.setBasicToken(appkeyvalue);

            loginService.makeCall(username, password, rememberme).then(function (accessTokenData) {
                if (accessTokenData.access_token !== "")
                {
                    sessionConfigurationService.setAccessTokenData(accessTokenData.access_token);
                    userPreferencesService.makeCall().then(function (userPreferencesData) {
                        if (userPreferencesData.d.userId !== "")
                        { 
                            sessionConfigurationService.setUserPreferences(userPreferencesData.d);
//                            $window.location.href = '/base.html';
                        }
                    });
                }
            });
        });
    };
我的appKeyService工厂是

app.factory('appKeyService', function ($q, authenticatedServiceFactory, configurationService) {
    var deffered = $q.defer();
    var service = {};

    service.makeCall = function () {
        debugAlert("appKeyService async method request start");
         authenticatedServiceFactory.makeCall("GET", configurationService.getAppKeyURL(), "", "").then(function (data) {
            debugAlert("appKeyService async method response")
            deffered.resolve(data);
        });
        return deffered.promise;
    };
    return service;
});
我的认证服务工厂是

app.factory('authenticatedServiceFactory', function ($http, $q, sessionConfigurationService) {
    var deffered = $q.defer();
    var service = {};
    service.makeCall = function (methodType, URL, data, authType) {

        var headerValue = "";
        if (authType === "Basic") {
            headerValue = sessionConfigurationService.getBasicToken();
        } else if (authType === "Bearer") {
            headerValue = sessionConfigurationService.getBearerToken();
        }

        var config = {headers: {
                'Authorization': headerValue,
                'Accept': 'application/json;odata=verbose',
            },
            withCredentials: true,
            async: false
        };
        if (methodType === "GET") {
            $http.get(URL, data, config)
                    .then(function (getData) {
                        debugAlert("GET method response" + JSON.stringify(getData));
                        deffered.resolve(getData.data);
                    }, function (error) {
                        debugAlert("GET method response error" + JSON.stringify(error));
                        deffered.reject(error);
                    });
        }
        else if (methodType === "POST") {
            $http.post(URL, data, config)
                    .then(function (putData) {
                        debugAlert("POST method response" + JSON.stringify(putData));
                        deffered.resolve(putData.data);
                    }, function (error) {
                        debugAlert("POST method response error" + JSON.stringify(error));
                        deffered.reject(error);
                    });
        }
        else if (methodType === "DELETE") {
            $http.delete(URL, data, config)
                    .then(function (deleteData) {
                        debugAlert("DELETE method response" + JSON.stringify(deleteData));
                        deffered.resolve(deleteData.data);
                    }, function (error) {
                        debugAlert("DELETE method response error" + JSON.stringify(error));
                        deffered.reject(error);
                    });
        }
        else if (methodType === "PUT") {
            $http.put(URL, config)
                    .then(function (putData) {
                        debugAlert("PUT method response" + JSON.stringify(putData));
                        deffered.resolve(putData.data);
                    }, function (error) {
                        debugAlert("PUT method response error" + JSON.stringify(error));
                        deffered.reject(error);
                    });
        }
        return deffered.promise;
    };
    return service;
});
但我看不到服务呼叫是同步进行的。因此,控制器中的“then”部分在我们收到响应后不执行。它一个接一个地执行。我怎样才能做到这一点

@Frane Poljak

谢谢你的评论。我刚带来

var deffered = $q.defer();
在makeCall方法中,它的工作方式与我现在想要的一样。谢谢大家!

app.factory('appKeyService', function ($q, authenticatedServiceFactory, configurationService) {
    var service = {};

    service.makeCall = function () {
    var deffered = $q.defer();

        debugAlert("appKeyService async method request start");
         authenticatedServiceFactory.makeCall("GET", configurationService.getAppKeyURL(), "", "").then(function (data) {
            debugAlert("appKeyService async method response")
            deffered.resolve(data);
        });
        return deffered.promise;
    };
    return service;
});
@弗兰·波尔雅克

谢谢你的评论。我刚带来

var deffered = $q.defer();
在makeCall方法中,它的工作方式与我现在想要的一样。谢谢大家!

app.factory('appKeyService', function ($q, authenticatedServiceFactory, configurationService) {
    var service = {};

    service.makeCall = function () {
    var deffered = $q.defer();

        debugAlert("appKeyService async method request start");
         authenticatedServiceFactory.makeCall("GET", configurationService.getAppKeyURL(), "", "").then(function (data) {
            debugAlert("appKeyService async method response")
            deffered.resolve(data);
        });
        return deffered.promise;
    };
    return service;
});

首先,您应该将var defered=$q.defer()放在;在service.makeCall函数中,promises不会使代码同步。他们只是帮助(很多)编写异步代码!您不需要一个
$q.defer()在这段代码中。首先,您应该将var deffered=$q.defer();在service.makeCall函数中,promises不会使代码同步。他们只是帮助(很多)编写异步代码!您不需要一个
$q.defer()在此代码中。