zoukankan      html  css  js  c++  java
  • 理解 Promise 过程

    /**
        new Promise(fn1).then(function(val){
                console.log(val);
                 
            }) 
    
          主要是把 then 的函数抽取出来 , 利用闭包存放在 callback中,  再把callback 封装成resole;
    
                resolve执行的时候, 可以传参数给callback执行;


    所以把 fn1 放在 new Promise的时候执行, 这时候的 fn1 被封装了, 带了一个回调函数, 而这个回调函数就是 then 里面的函数 new Promise(fn1), 执行fn1, 异步完成调用resolve, 虽然在new 的时候, callback是空, 但是.then(funtion(val){}) 的时候, callback就有方法了, 等异步完成, callback已经有值 **/ function Promise(fn){ //需要一个成功时的回调 var callback; //一个实例的方法,用来注册异步事件 this.then = function(done){ callback = done; }
    //把fn1放在Promise的执行, 把callback利用回调在resove调用后执行, 顺便传入一些参数 function resolve( dend ){ callback(dend); } fn(resolve); } function fn1(resolve) { setTimeout(function() { console.log('步骤一:执行'); resolve('1'); },500); } new Promise(fn1).then(function(val){ console.log(val); })   

    http://www.cnblogs.com/huansky/p/6064402.html

    segMentflag

  • 相关阅读:
    hdu--2522--循环节
    hdu--2523--读懂题意....
    hdu--1073--字符串处理
    hdu--1114--完全背包
    C#写入对象到XML/从XML读取对象
    C#打开另一个窗体
    Intent启动照片或者相机
    ViewGroup
    上传文件的表单
    添加菜单到fragment
  • 原文地址:https://www.cnblogs.com/dhsz/p/6693389.html
Copyright © 2011-2022 走看看