ajax 异步封装(Promise)

原生 js 实现;

  • onload 中之所以还要再进行状态码的验证,实际上是为了验证在网络通畅情况下,服务器发送的是否是正确数据;
  • onerror 则是用于判断网络是否中断的错误,不能用 onerror 来取代 onload 中的状态验证,两者针对完全不同的错误情况;
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>

<body>
    <button>提交</button>
    <script>
        function Ajax(request) {

            return new Promise(function (res, rej) {
                let xhr = new XMLHttpRequest();
                xhr.open(request.method, request.url);
                let data = request.data;
				
                xhr.onload = function () {
                    if (xhr.readyState === 4 && xhr.status === 200) {
                        res(xhr);
                    } else if (xhr.readyState === 4 && xhr.status !== 200) {
                        rej(xhr);
                    }
                }

                if (request.method === 'POST') {
                    if (request.header) {
                        xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
                    } else {
                        xhr.setRequestHeader('Content-Type', 'application/json');
                        data = JSON.stringify(request.data);
                    }
                    xhr.send(data);

                } else if (request.method === 'GET') {
                    xhr.send();
                }


            })
        }

        const request_form = {
            method: 'GET',
            url: 'https://api.apiopen.top/getJoke?page=1&count=2&type=video',
        }

        // const request_form = {
        //     method: 'POST',
        //     url: 'http://localhost:3000/json',
        //     data: {
        //         name: 'zhangsan',
        //         age: 30
        //     }
        // }

        const btn = document.querySelector('button');

        function test(request_form) {
            const first_request = Ajax(request_form);
            first_request.then(function (res) {
                const data = JSON.parse(res.response);
                console.log(data);
            }).catch(function (rej) {
                console.log(rej);
            })
        }

        btn.addEventListener('click', test.bind(this, request_form))

    </script>
</body>

</html>
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值