最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • JavaScript的异步编程

    正文概述 掘金(yanessa_yu)   2021-06-02   384

    回调函数

    发布订阅模式

    Promise

    手写Promise

    手写开始

    很多手写版本都是是有setTimeOut去做异步处理,但是setTimeOut属于宏任务,这与Promise是一个微任务相矛盾,所以要选择一种创建微任务的方式去实现。

    这里我们有几种选择,一种就是Promise A+规范中提到的,Promise.nextTick(Node端)与MutationObserver(浏览器端),考虑到利用这两种方式需要做环境判断,所以在推荐使用queueMicrotask创建微任务。

    Promise核心逻辑实现

    原生调用

    const promise = new Promise((resolve, reject) => {
        resolve( 'success' )
        reject ( 'err' )
    })
    
    promise.then( value => {
        console.log( 'resolve', value)
    }, reason => {
        console.log( 'reject', reason)
    })
    

    基本原理

    1. Promise是一个类,在执行这个类的时候会传入一个执行器,这个执行器会立即执行;
    2. Promise会有三种状态
    • pending 进行中
    • fulfilled 完成
    • rejected 失败
    1. 状态只能由pending -> fulfilled 或者pending -> rejected,且一旦发生改变便不可二次修改;
    2. Promise中使用resolve 和 reject 两个函数来改变状态;
    3. then 方法内部做的事情就是状态判断
    • 如果状态是成功,调用成功回调函数
    • 如果状态是失败,调用失败回调函数

    一篇关于手写Promise和分析Promise的好文章

    juejin.cn/post/695345…

    generator

    async await

    分析一道题,理解async的实现原理

    
    async function asyncFun1(){
       console.log('async start');
       await asyncFun2()
       await asyncFun3()
       await asyncFun4()
       console.log('async end')
    }
    
    async function  asyncFun2(){
        console.log('async await1');  
    }
    
    async function asyncFun3(){
        console.log('async await2')
    }
    
    async function asyncFun4(){
        console.log('async await3')
    }
    
    new Promise((reslove)=>{
        console.log('promise')
        reslove()
    }).then(()=>{
        console.log('promise then1')
    }).then(()=>{
        console.log('promise then2')
    }).then(()=>{
        console.log('promise then3')
    }).then(()=>{
        console.log('promise then4')
    })
    
    asyncFun1()
    
    

    输出结果为:

    promise
    async start
    async await1
    promise then1
    async await2
    promise then2
    async await3
    promise then3
    async end
    promise then4
    

    根据上面的输出结果,发现async函数里面从第二个await开始,就和promise.then交替输出,由此可分析出async await是基于微任务实现异步执行的。


    起源地下载网 » JavaScript的异步编程

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元