Promise及其应用

文章介绍了Promise作为异步编程解决方案的优势,通过对比传统的回调函数和使用Promise的示例,展示了Promise如何解决回调地狱问题,简化异步操作。同时,文章还提到了将异步函数转换为Promise模式的步骤,并结合AJAX展示了Promise在处理网络请求中的应用。
摘要由CSDN通过智能技术生成

一、介绍

Promise,译为承诺,是异步编程的一种解决方案,比传统的解决方案(回调函数)更加合理和更加强大,能够解决回调地狱的问题。

doSomething(function(result) {
  doSomethingElse(result, function(newResult) {
    doThirdThing(newResult, function(finalResult) {
      console.log('得到最终结果: ' + finalResult);
    }, failureCallback);
  }, failureCallback);
}, failureCallback);//回调地狱

但我们通过promise初体验,写一个定时器,来展现他的好处如下: 

<body>
    
    <button class="btn-1" id="btn">惦记我</button>
   
    <script>
        function rand(m,n){
            return Math.ceil(Math.random()*(n-m+1)) + m-1;
        }//随机函数
        var btn = document.querySelector('#btn');
        btn.addEventListener('click',function(){
            /* setTimeout(()=>{
                var t = rand(1,100)
                if(t<=30){
                    alert('zhongjiang')
                }
                else{
                    alert('no');
                }
            },1000) */
            const p = new Promise((resolve,reject) =>{
                setTimeout(()=>{
                var t = rand(1,100)
                if(t<=30){
                    //alert('zhongjiang')
                    resolve(t);
                }
                else{
                    //alert('no');
                    reject(t);
                }
            },1000);
            });
            p.then((value) =>{
                alert('yes'+ value);
            },(reason) =>{
                alert('no' + reason);
            });

        });
    </script>
</body>

瞬间感受到promise解决异步操作的优点:

  • 链式操作减低了编码难度
  • 代码可读性明显增强

特点

  • 对象的状态不受外界影响,只有异步操作的结果,可以决定当前是哪一种状态
  • 一旦状态改变(从pending变为fulfilled和从pending变为rejected),就不会再变,任何时候都可以得到这个结果

 二、异步与promise模式

如何让一个回调的异步函数变成Promis的异步函数 

  • 第一步
    • return new Promise((resolve,reject)+>{....})
    • 任务成功调用resolve(result)
    • 任务失败调用reject(error)
    • resolve和reject会再去调用成功和失败函数
  • 第二步
    • 使用.then(success,fail)传入成功和失败函数
  • 补充:promise不可被取消

三、promise与Ajax

1. 介绍

AJAX,是 Asynchronous JavaScript And XML,意思是利用JavaScript执行异步网络请求,对页面进行局部更新,而不需要重载页面。

AJAX是浏览器的功能,利用浏览器在window上增加的XMLHttpRequest函数,利用该函数构造出一个对象,使用该对象进行请求发送与响应接受。

2. 使用

  1. 创建一个XMLHttpRequest对象
  2. 调用对象的open方法启用。
  3. 监听对象的 onreadystatechange 事件(或者是onloadonerror事件),处理函数对返回的数据进行处理。
  4. 调用对象的send方法发送请求

3. onreadystatechange

状态描述
0UNSENT代理被创建,但尚未调用 open() 方法。
1OPENEDopen() 方法已经被调用。
2HEADERS_RECEIVEDsend() 方法已经被调用,并且头部和状态已经可获得。
3LOADING下载中; responseText 属性已经包含部分数据。
4DONE下载操作已完成。

创建 -> 打开 -> 发送 -> 接收 -> 完成

每一次state的改变都会触发readystatechange事件,但我们一般只关心state为4的阶段,此阶段数据接收已完成,可来进行数据处理。onload函数也会在请求完成后即state为4的时候调用。

<body>
    <div class="11" >
        <button id="btn"> 点击</button>
    </div>
    <script>
        const btn = document.querySelector('#btn');
        /* btn.addEventListener('click',function(){
            const xhr = new XMLHttpRequest();
            xhr.open('GET','https://api.apiopen.top/getJok');
            xhr.send();
            xhr.onreadystatechange = function(){
                if(xhr.readyState === 4){
                    if(xhr.status>=200 && xhr.status <300){
                         console.log(xhr.response); 
                    }
                    else{
                        console.log(xhr.status);
                    }
                }
            }
        }); */
        btn.addEventListener('click',function(){
             const p =new Promise((resolve,reject)=>{
            const xhr = new XMLHttpRequest();
            xhr.open('GET','https://api.apiopen.top/getJok');
            xhr.send();
            xhr.onreadystatechange = function(){
                if(xhr.readyState === 4){
                    if(xhr.status>=200 && xhr.status <300){
                         //console.log(xhr.response); 
                         resolve(xhr.response);
                    }
                    else{
                        //console.log(xhr.status);
                        reject(xhr.status);
                    }
                }
            }
            });
            p.then(value =>{
                console.log(value)
            },reson =>{
                console.warn(reason)
            })
        });
       
    </script>
</body>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值