一、事件循環(huán)

JavaScript是單線程,同一個(gè)時(shí)間只能做一件事情,所以執(zhí)行任務(wù)需要排隊(duì)。如果前一個(gè)耗時(shí)很長,那么下一個(gè)只能等待。

1)兩種任務(wù)

為了更好的處理任務(wù),JavaScript語言的設(shè)計(jì)者將任務(wù)分為兩種:同步任務(wù)(synchronous)與異步任務(wù)(asynchronous)。

同步任務(wù):在主線程上排隊(duì)執(zhí)行的任務(wù)。

異步任務(wù):放在“任務(wù)隊(duì)列”(task queue)中,只有當(dāng)主線程空了,才會(huì)將“任務(wù)隊(duì)列”中的任務(wù)放到主線程中。

這就是JavaScript的運(yùn)行機(jī)制,這個(gè)過程會(huì)不斷重復(fù),這個(gè)機(jī)制叫事件循環(huán)(Event Loop)。

2)事件循環(huán)

事件循環(huán)模型可以用下圖描述,圖片來自Philip Roberts的演講《Help, I’m stuck in an event loop》:

平面設(shè)計(jì)培訓(xùn),網(wǎng)頁設(shè)計(jì)培訓(xùn),美工培訓(xùn),游戲開發(fā),動(dòng)畫培訓(xùn)

1. “WebAPIs”內(nèi)的就是異步任務(wù),包括DOM事件、Ajax和setTimeout。

2. “callback queue”內(nèi)的是一個(gè)任務(wù)隊(duì)列,包括click、load、done。

網(wǎng)友評(píng)論