javascript 之異步執(zhí)行幾個(gè)模式

1秩霍、回調(diào)函數(shù)

function f1(callback) {
  // f1 的代碼

  // f1 執(zhí)行完成后帮掉,調(diào)用回調(diào)函數(shù)
  callback();
}

類(lèi)同于

f1(f2);

2壮锻、采用時(shí)間驅(qū)動(dòng)模式,事件監(jiān)聽(tīng)

function f1(){
  setTimeout(function () {
    // f1的任務(wù)代碼
    f1.trigger('done');
  }, 1000);
}

function f2(){
console.log('事件監(jiān)聽(tīng)');
}
f1.on('done',f2);

3倍靡、發(fā)布訂閱,類(lèi)同于rabbitmq生產(chǎn)者课舍,消費(fèi)者機(jī)制

function f1(){
    setTimeout(function () {
        // f1的任務(wù)代碼
        jQuery.publish("done");
    }, 1000);
}
jQuery.subscribe("done", f2);

異步流程控制

async(1, function(value){
  async(value, function(value){
    async(value, function(value){
      async(value, function(value){
        async(value, function(value){
          async(value, final);
        });
      });
    });
  });
});
```

串行執(zhí)行
```javascript
var items = [ 1, 2, 3, 4, 5, 6 ];
var results = [];
function series(item) {
  if(item) {
    async( item, function(result) {
      results.push(result);
      return series(items.shift());
    });
  } else {
    return final(results);
  }
}
series(items.shift());
```

并行執(zhí)行
```javascript
var items = [ 1, 2, 3, 4, 5, 6 ];
var results = [];

items.forEach(function(item) {
  async(item, function(result){
    results.push(result);
    if(results.length == items.length) {
      final(results);
    }
  })
});
```

并行與串行的結(jié)合
```javascript

var items = [ 1, 2, 3, 4, 5, 6 ];
var results = [];
var running = 0;
var limit = 2;

function launcher() {
  while(running < limit && items.length > 0) {
    var item = items.shift();
    async(item, function(result) {
      results.push(result);
      running--;
      if(items.length > 0) {
        launcher();
      } else if(running == 0) {
        final(results);
      }
    });
    running++;
  }
}
launcher();
```

promise
```javascript
(new Promise(f1)).then(f2);
```

```javascript
// 傳統(tǒng)寫(xiě)法
step1(function (value1) {
  step2(value1, function(value2) {
    step3(value2, function(value3) {
      step4(value3, function(value4) {
        // ...
      });
    });
  });
});

// Promises的寫(xiě)法
(new Promise(step1))
  .then(step2)
  .then(step3)
  .then(step4);
```

Promise對(duì)象的優(yōu)點(diǎn)在于塌西,讓回調(diào)函數(shù)變成了規(guī)范的鏈?zhǔn)綄?xiě)法




最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市筝尾,隨后出現(xiàn)的幾起案子捡需,更是在濱河造成了極大的恐慌,老刑警劉巖筹淫,帶你破解...
    沈念sama閱讀 206,214評(píng)論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件站辉,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡贸街,警方通過(guò)查閱死者的電腦和手機(jī)庵寞,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評(píng)論 2 382
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)薛匪,“玉大人捐川,你說(shuō)我怎么就攤上這事∫菁猓” “怎么了古沥?”我有些...
    開(kāi)封第一講書(shū)人閱讀 152,543評(píng)論 0 341
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)娇跟。 經(jīng)常有香客問(wèn)我岩齿,道長(zhǎng),這世上最難降的妖魔是什么苞俘? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 55,221評(píng)論 1 279
  • 正文 為了忘掉前任盹沈,我火速辦了婚禮,結(jié)果婚禮上吃谣,老公的妹妹穿的比我還像新娘乞封。我一直安慰自己做裙,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評(píng)論 5 371
  • 文/花漫 我一把揭開(kāi)白布肃晚。 她就那樣靜靜地躺著锚贱,像睡著了一般。 火紅的嫁衣襯著肌膚如雪关串。 梳的紋絲不亂的頭發(fā)上拧廊,一...
    開(kāi)封第一講書(shū)人閱讀 49,007評(píng)論 1 284
  • 那天,我揣著相機(jī)與錄音晋修,去河邊找鬼吧碾。 笑死,一個(gè)胖子當(dāng)著我的面吹牛飞蚓,可吹牛的內(nèi)容都是我干的滤港。 我是一名探鬼主播,決...
    沈念sama閱讀 38,313評(píng)論 3 399
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼趴拧,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了山叮?” 一聲冷哼從身側(cè)響起著榴,我...
    開(kāi)封第一講書(shū)人閱讀 36,956評(píng)論 0 259
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎屁倔,沒(méi)想到半個(gè)月后脑又,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,441評(píng)論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡锐借,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評(píng)論 2 323
  • 正文 我和宋清朗相戀三年问麸,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片钞翔。...
    茶點(diǎn)故事閱讀 38,018評(píng)論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡严卖,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出布轿,到底是詐尸還是另有隱情哮笆,我是刑警寧澤,帶...
    沈念sama閱讀 33,685評(píng)論 4 322
  • 正文 年R本政府宣布汰扭,位于F島的核電站稠肘,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏萝毛。R本人自食惡果不足惜项阴,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評(píng)論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望笆包。 院中可真熱鬧环揽,春花似錦略荡、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,240評(píng)論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至跨扮,卻和暖如春序无,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背衡创。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,464評(píng)論 1 261
  • 我被黑心中介騙來(lái)泰國(guó)打工帝嗡, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人璃氢。 一個(gè)月前我還...
    沈念sama閱讀 45,467評(píng)論 2 352
  • 正文 我出身青樓哟玷,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親一也。 傳聞我的和親對(duì)象是個(gè)殘疾皇子巢寡,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評(píng)論 2 345

推薦閱讀更多精彩內(nèi)容

  • 弄懂js異步 講異步之前,我們必須掌握一個(gè)基礎(chǔ)知識(shí)-event-loop椰苟。 我們知道JavaScript的一大特點(diǎn)...
    DCbryant閱讀 2,695評(píng)論 0 5
  • 你不知道JS:異步 第三章:Promises 接上篇3-1 錯(cuò)誤處理(Error Handling) 在異步編程中...
    purple_force閱讀 1,384評(píng)論 0 2
  • 異步編程對(duì)JavaScript語(yǔ)言太重要抑月。Javascript語(yǔ)言的執(zhí)行環(huán)境是“單線(xiàn)程”的,如果沒(méi)有異步編程舆蝴,根本...
    呼呼哥閱讀 7,298評(píng)論 5 22
  • 你不知道JS:異步 第三章:Promises 在第二章谦絮,我們指出了采用回調(diào)來(lái)表達(dá)異步和管理并發(fā)時(shí)的兩種主要不足:缺...
    purple_force閱讀 2,052評(píng)論 0 4
  • 官方中文版原文鏈接 感謝社區(qū)中各位的大力支持,譯者再次奉上一點(diǎn)點(diǎn)福利:阿里云產(chǎn)品券洁仗,享受所有官網(wǎng)優(yōu)惠层皱,并抽取幸運(yùn)大...
    HetfieldJoe閱讀 8,676評(píng)論 0 29