ajax和promise以及async await的实践分析

1. 使用ajax请求一个文件

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <h1 id="content">.........</h1>
    <button id="btn">点我读取文件</button>
    <script>
        var content = document.getElementById('content');
        var btn = document.getElementById('btn');
        function ajax(method, url, data, successFn, failFn) {
            let xhr = new XMLHttpRequest();
            xhr.open(method, url);
            xhr.send();
            xhr.onreadystatechange = function() {
                console.log(xhr,'==========')
                if (xhr.readyState == '4') {
                    if (xhr.status == '200') {
                        //成功回调
                        successFn(xhr.responseText);
                    } else {
                        failFn(xhr.status);
                    }
                }
            };
        }
        
        function successFn(responTest) {
            console.log(responTest, '成功');
            content.innerText = responTest;
        }
        function failFn(status) {
            console.log(status, '失败');
        }
       btn.onclick = function(){
        ajax('get', './1.txt', {}, successFn, failFn);
       }
    </script>  
    
</body>
</html>

对应的文件1.txt

hello world

2.使用promise 和 async await 来分别处理一个请求和两个请求

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>
    <h1 id="content">文件1内容</h1>
    <h1 id="content_one">文件2内容</h1>
    <button id="btn">点我读取文件1</button>
    <button id="btn_two">点我读取文件2</button>
    <button id="btn_three">点击读取文件1和文件2(先一后二)</button>
    <button id="btn_four">读取文件1和文件2(都读取完毕再做处理)</button>
    <button id="btn_five">读取文件1和文件2(那个请求快处理哪个)</button>
    <button id="btn_six">先后读取文件1和文件2(async await)</button>
    <script src="http://code.jquery.com/jquery-2.1.1-rc2.min.js"></script>
    <script>
        let content = document.getElementById('content');
        let content_one = document.getElementById('content_one');
        let btn = document.getElementById('btn');
        let btn_two =  document.getElementById('btn_two');
        let btn_three = document.getElementById('btn_three');
        let btn_four = document.getElementById('btn_four');
        let btn_five = document.getElementById('btn_five');
        let btn_six = document.getElementById('btn_six');
        //包装的ajax 用于请求数据
        function ajaxPromise(url,method,data) {
            var pro = new Promise(function(resolve, reject) {
                var ajax = new XMLHttpRequest();
                var method=method||"GET"
                    var data=data ||null
                ajax.open(method, url);
                ajax.send(data);
                ajax.onreadystatechange = function() {
                    if (ajax.readyState == 4) {
                        if(ajax.status == '200'){
                            console.log(resolve,'======')
                            resolve(ajax.responseText);
                        }else{
                            reject(ajax.status);
                        }
                    }
                }
                
            })
            return pro;
        }

        //1.使用promise then的链式调用的方式 传入请求成功和失败的回调 来执行成功的逻辑和捕获异常

        btn.addEventListener('click',()=>{
            ajaxPromise("./1.txt").then(function(msg) {
                console.log(msg,'请求成功');
                content.innerText = msg;
            }, function(msg) {
                console.log(msg,'请求失败');
                content.innerText = msg;
            })
        })

        //2.使用async await方式来处理该请求 使用try catch来处理请求成功的逻辑和捕获异常

        btn_two.addEventListener('click',async ()=>{
            try{
                let res = await ajaxPromise("./1.json");
                console.log(res,'哈哈哈哈哈哈');
                let {success,data} = JSON.parse(res);
                if(success){
                    console.log(data,'请求成功');
                    let {showColumnsMap} = data;
                    let listArr = [];
                    Object.keys(showColumnsMap).forEach((key)=>{
                        listArr.push(showColumnsMap[key])
                    })
                    console.log(listArr,'=====')
                    let contentDom = listArr.map((item)=>{
                        return `<div>${item}<div/>`
                    })
                    console.log(contentDom,'=====')
                    content_one.innerHTML = contentDom.join('');
                    
                }
            }catch(error){
                console.log(error,'请求失败')
            }
        })

        //3.使用promise的then的链式调用方式 先后发两个请求 请求成功第一个文件后,再请求第二个文件 但凡第一个请求失败了,第二个请求也就不会去触发 被阻断了

        btn_three.addEventListener('click',()=>{
            ajaxPromise("./1.txt").then(function(msg) {
                console.log(msg,'第一个文件请求成功');
                content.innerText = msg;
                ajaxPromise('./1.json').then((res)=>{
                    let {success,data} = JSON.parse(res);
                    if(success){
                        console.log(data,'第二个文件请求成功');
                        let {showColumnsMap} = data;
                        let listArr = [];
                        Object.keys(showColumnsMap).forEach((key)=>{
                            listArr.push(showColumnsMap[key])
                        })
                        console.log(listArr,'=====')
                        let contentDom = listArr.map((item)=>{
                            return `<div>${item}<div/>`
                        })
                        console.log(contentDom,'=====')
                        content_one.innerHTML = contentDom.join('');
                    }
                },(err)=>{
                    console.log(err,'第二个文件请求失败')
                })
            }, function(msg) {
                console.log(msg,'第一个文件请求失败');
                content.innerText = msg;
            })
        });

        //4. 使用promise all的方式 请求两个接口,都成功后对于请求到的数据进行统一处理
        btn_four.addEventListener('click',()=>{
            Promise.all([ajaxPromise("./1.txt"),ajaxPromise('./1.json')]).then((res)=>{
                console.log(res,'请求成功')
                //处理第一个请求回来的数据
                let msg1 = res[0];
                content.innerText = msg1;
                //处理第二个请求回来的数据
                let dataObj = JSON.parse(res[1]);
                console.log(dataObj,'=======');
                let {data} = dataObj;
                console.log(data,'第二个文件请求成功');
                let {showColumnsMap} = data;
                let listArr = [];
                Object.keys(showColumnsMap).forEach((key)=>{
                    listArr.push(showColumnsMap[key])
                })
                console.log(listArr,'=====')
                let contentDom = listArr.map((item)=>{
                    return `<div>${item}<div/>`
                })
                console.log(contentDom,'=====')
                content_one.innerHTML = contentDom.join('');
            },(err)=>{
                console.log(err,'请求出错')
            })
        });

        //5. 使用promise race的方式 请求两个接口,于先完成的请求到的数据进行处理 如果某一个请求出错了,不会影响另外一个请求
        btn_five.addEventListener('click',()=>{
            Promise.race([ajaxPromise("./11.txt"),ajaxPromise('./1.json')]).then((res)=>{
                console.log(res,'请求成功');
                let resArr = res.split(' ');
                console.log(resArr,'===========')
                console.log(resArr,'===========')
                if(resArr.length<=2){
                    //处理第一个请求回来的数据
                    content.innerText = res;
                }else{
                    let {success,data} = JSON.parse(res);
                    if(success){
                        //处理第二个请求回来的数据
                        console.log(data,'第二个文件请求成功');
                        let {showColumnsMap} = data;
                        let listArr = [];
                        Object.keys(showColumnsMap).forEach((key)=>{
                            listArr.push(showColumnsMap[key])
                        })
                        console.log(listArr,'=====')
                        let contentDom = listArr.map((item)=>{
                            return `<div>${item}<div/>`
                        })
                        console.log(contentDom,'=====')
                        content_one.innerHTML = contentDom.join('');
                    }
                }
                
            },(err)=>{
                console.log(err,'请求出错')
            })
        });

        //6. 使用async await 的方式 哪个写在前面哪个先请求,一个请求失败,另一个也会被阻断。 使用这样的方式好处是在有异步回调嵌套的情况下比单纯的使用promise看起来代码逻辑和结构更清晰,
        //避免了回调嵌套回调的回调地狱问题,async await 的使用try catch来处理成功和捕获异常
        btn_six.addEventListener('click',async ()=>{
            try{
                let res2 = await ajaxPromise("./1.json");
                console.log(res2,'=========');
                if(res2){
                    let {success,data} = JSON.parse(res2);
                    if(success){
                        //处理第二个请求回来的数据
                        console.log(data,'第二个文件请求成功');
                        let {showColumnsMap} = data;
                        let listArr = [];
                        Object.keys(showColumnsMap).forEach((key)=>{
                            listArr.push(showColumnsMap[key])
                        })
                        console.log(listArr,'=====')
                        let contentDom = listArr.map((item)=>{
                            return `<div>${item}<div/>`
                        })
                        console.log(contentDom,'=====')
                        content_one.innerHTML = contentDom.join('');
                    }

                }
                let res1 = await ajaxPromise("./1.txt");
                console.log(res1,'========');
                if(res1){
                     //处理第一个请求回来的数据
                     content.innerText = res1;
                }
            }catch(error){
                console.log(error,'请求出错')
            }
            
        })



        
       
    </script>
    
    
</body>
</html>

对应的文件1.json

{
    "data": {
        "showColumnsMap": {
            "keyval2": "币种",
            "keyval3": "会计月",
            "inputstate": "录入标志",
            "pk_task": "所属任务",
            "finalfilecount": "管理报告数量",
            "pk_org": "报表主组织",
            "pk_report": "报表",
            "taskcheckstate": "任务审核状态",
            "inputperson": "录入人",
            "repcheckstate": "报表审核状态",
            "repcommitstate": "报表上报状态",
            "inputtime": "录入时间",
            "taskcommitstate": "任务上报状态"
        }
    },
    "success": true
}


以上实例即是ajax ,promise, async和await来处理异步的一些对比和分析。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容