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

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 13:29:24
字體:
來源:轉載
供稿:網友

在實際業務中經常需要等待幾個請求完成后再進行下一步操作。但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的詳細使用方法網上的有很多教程。我也是剛接觸。講不好,不敢亂講。上面的代碼是我按我的理解寫的,經過了測試沒有問題。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 广南县| 泽库县| 万州区| 黑水县| 石泉县| 绥芬河市| 舟曲县| 五原县| 平陆县| 石城县| 鱼台县| 神木县| 卓资县| 德江县| 浦北县| 东台市| 黄山市| 鹤岗市| 唐海县| 平武县| 潜山县| 津市市| 汉川市| 盱眙县| 武义县| 武穴市| 海阳市| 万宁市| 米脂县| 保康县| 石门县| 普陀区| 津南区| 永昌县| 饶河县| 永泰县| 商城县| 福海县| 石楼县| 乌兰察布市| 太白县|