javascript异步发展史

js中的异步是指一个函数在执行过程中,其中一部分不能马上执行完毕,然后执行函数体中另外一部分。等到第一部分得到返回值再执行第二部分。

1.回调函数callback

无法捕获错误 try catch

不能return

回调地狱

  function personInfo(callback){

    $.ajax({

          type: "GET",

          url: "test.json", 

          data: {

                username:username,

                content:content

          },

        dataType: "json",

        success: function(data){

              if(data.length>0){

                    callback&&callback();

              }

        }

  });

}

2.事件发布/订阅模型

给一个事件,订阅几个方法,方法依次执行。

function Event() {

    this.event = {};

}

Event.prototype.on = function (type,callBack) {

    if(this.event[type]){

        this.event[type].push(callBack);

    }else{

        this.event[type] = [callBack];

    }

};

Event.prototype.emit = function (type,...data) {

    this.event[type].forEach((item)=>item(...data));

};

let event = new Event();

function fn1(){

  console.log('吃饭');

}

function fn2(){

    console.log('工作');

}

event.on('我的一天',fn1);

event.on('我的一天',fn2);

event.emit('我的一天');

3.Promise异步函数解决方案

  A执行完执行B,B执行完执行C。把A的返回值给B再给C

每一次执行,返回一个新的Promise实例(链式调用)

  代码易读

let p1 = new Promise(function(resolve,reject){

  reject(10000000);

});

p1.then(function(value){

  console.log('成功1=',value);

},function(reason){

  console.log('失败1=',reason);

});

p1.then(function(value){

  console.log('成功2=',value);

},function(reason){

  console.log('失败2=',reason);

});

4.Generator生成器函数

调用一个生成器函数它不会立刻执行

它返回一个迭代器函数,每调用一次next就可以返回一个值对象

function *go(a){

    console.log(1);

    let b =  yield a;

    console.log(2);

    let c = yield b;

    console.log(3);

    return c;

}

let it = go("a值");

let r1 = it.next();

let r2 = it.next('B值');

5.Co

co是一个为Node.js和浏览器打造的基于生成器的流程控制工具,借助于Promise,你可以使用更加优雅的方式编写非阻塞代码。

let fs = require('fs');

function readFile(filename) {

  return new Promise(function (resolve, reject) {

    fs.readFile(filename, function (err, data) {

      if (err)

        reject(err);

      else

        resolve(data);

    })

  })

}

function *read() {

  let template = yield readFile('./template.txt');

  let data = yield readFile('./data.txt');

  return template + '+' + data;

}

co(read).then(function (data) {

  console.log(data);

}, function (err) {

  console.log(err);

});

function co(gen) {

  let it = gen();

  return new Promise(function (resolve, reject) {

    !function next(lastVal) {

      let {value, done} = it.next(lastVal);

      if (done) {

        resolve(value);

      } else {

        value.then(next, reason => reject(reason));

      }

    }();

  });

}

6.Async/ await

可以实现和co一样的功能

结构简单,可读性强

let fs = require('fs');

function readFile(filename) {

  return new Promise(function (resolve, reject) {

    fs.readFile(filename, 'utf8', function (err, data) {

      if (err)

        reject(err);

      else

        resolve(data);

    })

  })

}

async function read() {

  let template = await readFile('./template.txt');

  let data = await readFile('./data.txt');

  return template + '+' + data;

}

let result = read();

result.then(data=>console.log(data));

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • Promise 对象 Promise 的含义 Promise 是异步编程的一种解决方案,比传统的解决方案——回调函...
    neromous阅读 8,741评论 1 56
  • 欢迎阅读专门探索 JavaScript 及其构建组件的系列文章的第四章。 在识别和描述核心元素的过程中,我们还分享...
    OSC开源社区阅读 1,176评论 1 10
  • 在ES6当中添加了很多新的API其中很值得一提的当然少不了Promise,因为Promise的出现,很轻松的就给开...
    嘿_那个谁阅读 3,689评论 2 3
  • 前言 本文旨在简单讲解一下javascript中的Promise对象的概念,特性与简单的使用方法。并在文末会附上一...
    _暮雨清秋_阅读 2,263评论 0 3
  • 特点 Promise能将回调分离出来,在异步操作执行之后,用链式方法执行回调,虽然es5用封装函数也能实现,但是如...
    一二三kkxx阅读 642评论 0 1