av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

javascript - Async/Await報錯

瀏覽:83日期:2023-09-02 08:25:08

問題描述

這段代碼問題在哪,一運行就報錯

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) }

javascript - Async/Await報錯

問題解答

回答1:

await 只能在 async 包裝的函數里面用。就和yield只能在generator函數里面用一樣。

回答2:

樓上不是說了嗎,丟到async函數里。

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函數里 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 函數(函數,函數表達式,箭頭函數) 中使用,所以你只需要寫個 async 函數把那段代碼包起來就好了,我比較喜歡寫 main 函數而不是直接在全局作用域內運行

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); }}// 記得調用main();

另外也可以使用 async IIFE 表達式,比如

// IIFE 函數表達式(async function() { // todo main process})();// IIFE Lambda 表達式(箭頭函數表達式)(async () => { // todo main process})();

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 影音先锋成人资源 | 精品在线播放 | 成人精品在线观看 | 特黄小视频 | 精品一级 | 久久久青草婷婷精品综合日韩 | 国产精品2| 91精品国产综合久久香蕉922 | 国产成人免费在线 | 欧美a区 | 久久国产麻豆 | 国产激情免费视频 | 国产成人亚洲精品 | 亚洲女人天堂成人av在线 | 在线观看成人小视频 | 亚洲一区二区中文字幕在线观看 | 一级片成人 | 国产一区二区三区久久久久久久久 | 老司机精品福利视频 | 男女羞羞视频免费 | 黄色一级大片在线观看 | 国产午夜精品一区二区三区四区 | 亚洲国产一区视频 | 亚洲人精品午夜 | 国产98在线 | 免费, | 国产精品一区二区三区在线 | 日韩欧美专区 | 91九色视频在线 | 中文字幕第一页在线 | 久久久国产亚洲精品 | av在线免费播放 | 国产午夜精品一区二区三区嫩草 | 亚洲成人免费视频在线观看 | 国产精品视屏 | 日韩高清中文字幕 | 在线观看成人 | 国产一区91精品张津瑜 | 亚洲国产小视频 | 久久精品亚洲精品 | 啪视频在线 | 啪啪毛片|