javascript await学习

await 强制后面点代码等待,直到Promise对象resolve,得到resolve的值作为await表达式的运算结果

bash 复制代码
let sArr = ['没有数据'];
function timeout(ms) {
    return new Promise((resolve, reject) => {
      console.log('我已经调用了');  
      setTimeout(() => {//模拟耗时的操作,比如从数据库取数据,取出来后才能用
        //console.log('我需要等待');
        this.sArr =['我获取到数据了'];
        //reject('error');
        resolve(this.sArr);
 }, 5000);  //reject模拟出错,返回error
    //resolve('success');
    });
  }
  async function asyncPrint() {
    try {
       console.log('start');
       await timeout();  //可以去掉await 试试看输出结果
       //console.log(abc);
       //console.log('end');
       console.log(this.sArr);
    } catch(err) {
       console.log(err); //这里捕捉错误error
    }
  }

asyncPrint();
console.log('我继续执行,不受影响');

JS中console的几种方法
10 个关于 Promise 和 setTimeout 知识的面试题,通过图解一次说透彻
js异步编程 setTimeout、Promise、Async/Await 的区别

相关推荐
爱学习的茄子17 分钟前
JavaScript事件循环深度解析:理解异步执行的本质
前端·javascript·面试
1024小神18 分钟前
cocos游戏开发中多角色碰撞,物理反弹后改变方向的实现逻辑
前端·javascript
ruanhongbiao19 分钟前
饿了么el-upload上传组件报错:TypeError: ***.upload.addEventListener is not a function
javascript·elementui
_一两风20 分钟前
JS执行机制-event loop
javascript
止观止20 分钟前
JavaScript对象创建9大核心技术解析
开发语言·javascript·ecmascript
1024小神22 分钟前
cocos游戏开发中,如何制作一个空气墙
前端·javascript
爱编程的喵22 分钟前
深入理解JavaScript事件循环机制:从同步到异步的完整解析
前端·javascript
202623 分钟前
11. vite打包优化
前端·javascript·vite
1024小神33 分钟前
Cocos游戏开发中,检测两个物体碰撞,并实现物理反弹逻辑
前端·javascript
一一一8711 小时前
javaScript数据存储, 对象和原型与原型链
javascript