javascript - Async/Await报错
问题描述
这段代码问题在哪,一运行就报错
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) }
问题解答
回答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})();
相关文章:
1. PHP类中的$this2. javascript - 请教如何获取百度贴吧新增的两个加密参数3. javascript - 使用百度文本编辑器ueditor不显示样式问题4. python - 用__call__ 实现装饰器功能5. html5 - canvas有时候会拿不到toDataURL数据6. java - win10 下有什么好的输入法可以在idea下正常输入吗?7. android - 安卓实现类似QQ刚换聊天背景的功能8. 微信小程序9. javascript - 微信小程序 wx.downloadFile下载文件大小有限制吗10. css - html文件上传到虚拟主机后使用谷歌浏览器打开html元素的宽度变大
