javascript - Async/Await報(bào)錯(cuò)
問(wèn)題描述
這段代碼問(wèn)題在哪,一運(yùn)行就報(bào)錯(cuò)
var sleep = async function(para) {return new Promise(function(resolve, reject) { setTimeout(function() {resolve(para * para) }, 1000)}) } var errorSleep =async function(para) {return new Promise(function(resolve, reject) { setTimeout(function() {reject(’ ErrorSleep’) }, 1000)}) } try {var result1 = await sleep(1);var result2 = await errorSleep(4);var result3 = await sleep(1);console.log(’result1: ’, result1)console.log(’result2: ’, result2)console.log(’result3: ’, result3) } catch (err) {console.log(’err: ’, err)console.log(’result1: ’, result1)console.log(’result2: ’, result2)console.log(’result3: ’, result3) }

問(wèn)題解答
回答1:await 只能在 async 包裝的函數(shù)里面用。就和yield只能在generator函數(shù)里面用一樣。
回答2:樓上不是說(shuō)了嗎,丟到async函數(shù)里。
var sleep = async function(para) {return new Promise(function(resolve, reject) { setTimeout(function() {resolve(para * para) }, 1000)}) } var errorSleep =async function(para) {return new Promise(function(resolve, reject) { setTimeout(function() {reject(’ ErrorSleep’) }, 1000)}) }//一樣丟到async函數(shù)里 var af = async function() {try { var result1 = await sleep(1); var result2 = await errorSleep(4); var result3 = await sleep(1); console.log(’result1: ’, result1) console.log(’result2: ’, result2) console.log(’result3: ’, result3)} catch (err) { console.log(’err: ’, err) console.log(’result1: ’, result1) console.log(’result2: ’, result2) console.log(’result3: ’, result3)} } af();回答3:
await 只能在 async 函數(shù)(函數(shù),函數(shù)表達(dá)式,箭頭函數(shù)) 中使用,所以你只需要寫個(gè) async 函數(shù)把那段代碼包起來(lái)就好了,我比較喜歡寫 main 函數(shù)而不是直接在全局作用域內(nèi)運(yùn)行
async function main() { try {var result1 = await sleep(1);var result2 = await errorSleep(4);var result3 = await sleep(1);console.log('result1: ', result1);console.log('result2: ', result2);console.log('result3: ', result3); } catch (err) {console.log('err: ', err);console.log('result1: ', result1);console.log('result2: ', result2);console.log('result3: ', result3); }}// 記得調(diào)用main();
另外也可以使用 async IIFE 表達(dá)式,比如
// IIFE 函數(shù)表達(dá)式(async function() { // todo main process})();// IIFE Lambda 表達(dá)式(箭頭函數(shù)表達(dá)式)(async () => { // todo main process})();
相關(guān)文章:
1. docker-compose中volumes的問(wèn)題2. java - SSH框架中寫分頁(yè)時(shí)service層中不能注入分頁(yè)類3. boot2docker無(wú)法啟動(dòng)4. docker安裝后出現(xiàn)Cannot connect to the Docker daemon.5. javascript - vue生成一維碼?求助!!!!!急6. nignx - docker內(nèi)nginx 80端口被占用7. javascript - mock.js可以存儲(chǔ)數(shù)據(jù)嗎8. docker網(wǎng)絡(luò)端口映射,沒(méi)有方便點(diǎn)的操作方法么?9. javascript - js如何獲取app保存的TOKEN?10. 老師,按tab鍵不起作用怎么回事

網(wǎng)公網(wǎng)安備