国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

angularjs 處理多個異步請求方法匯總

2024-05-06 16:13:45
字體:
來源:轉載
供稿:網友
這篇文章主要介紹了angularjs 處理多個異步請求方法匯總,需要的朋友可以參考下
 

在實際業務中經常需要等待幾個請求完成后再進行下一步操作。但angularjs中$http不支持同步的請求。

解決方法一:

 

復制代碼代碼如下:

$http.get('url1').success(function (d1) {
        $http.get('url2').success(function (d2) {
            //處理邏輯
        });
    });

 

解決方法二:

then中的方法會按順序執行。

 

復制代碼代碼如下:

var app = angular.module('app',[]);
app.controller('promiseControl',function($scope,$q,$http) {
    function getJson(url){
        var deferred = $q.defer();
        $http.get(url)
            .success(function(d){
                d = parseInt(d);
                console.log(d);
                deferred.resolve(d);
            });
        return deferred.promise;
    }

 

    getJson('json1.txt').then(function(){
        return getJson('json2.txt');
    }).then(function(){
        return getJson('json1.txt');
    }).then(function(){
        return getJson('json2.txt');
    }).then(function(d){
        console.log('end');
    });
});

 

解決方法三:

$q.all方法第一個參數可以是數組(對象)。在第一參數中內容都執行完后就會執行then中方法。第一個參數的方法的所有返回值會以數組(對象)的形式傳入。

 

復制代碼代碼如下:

var app = angular.module('app',[]);
app.controller('promiseControl',function($scope,$q,$http) {
    $q.all({first: $http.get('json1.txt'),second: $http.get('json2.txt')}).then(function(arr){
        console.log(arr);
        angular.forEach(arr,function(d){
            console.log(d);
            console.log(d.data);
        })
    });
});

 

$q的詳細使用方法網上的有很多教程。我也是剛接觸。講不好,不敢亂講。上面的代碼是我按我的理解寫的,經過了測試沒有問題。


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表

圖片精選

主站蜘蛛池模板: 唐河县| 普安县| 衢州市| 偃师市| 扎囊县| 长治市| 团风县| 泰来县| 纳雍县| 梧州市| 永新县| 舞阳县| 沂南县| 神木县| 扎囊县| 滦南县| 江安县| 孟津县| 延川县| 宾阳县| 平顶山市| 呼和浩特市| 衢州市| 惠东县| 南溪县| 太和县| 嘉兴市| 商丘市| 阳山县| 文昌市| 宜昌市| 济南市| 北安市| 女性| 镇安县| 呼和浩特市| 阜新市| 茂名市| 天峻县| 兴和县| 五大连池市|