JavaScript 异步 setTimeout promise async await

异步在此就不再赘述,下面主要说一下JS中异步的实现方式。

1,setTimeout 计时器 ,实现代码如下




    
    
    
    Document



    

2,Promise ,简单用法如下:

Promise 构造函(即function (resolve, reject) { // 要做的事情...})数只有一个参数,是一个函数,这个函数在构造之后会直接被异步运行,所以我们称之为起始函数。起始函数包含两个参数 resolve 和 reject。resolve 和 reject 都是函数,其中调用 resolve 代表一切正常,reject 是出现异常时所调用的:

在构造函数中的内容是同步运行。如下

    

运行结果如下:

 显而易见,先执行console.log("new a promise"),然后执行console.log("last console")

Promise,完成结构如下:

Promise().then().catch().finally()

then内开始异步运行,catch 异常捕捉,finaly 整个代码执行完后执行的代码

 

执行结果如下:

JavaScript 异步 setTimeout promise async await_第1张图片

 先执行  console.log("last console")

然后执行then,

最后执行 finally。

执行了 resolve 即进入了then,不在执行reject。

如果将resolve和reject换一下位置 ,执行了reject函数 跳到catch 则不会执行 then函数

  

执行结果如下:

JavaScript 异步 setTimeout promise async await_第2张图片

由输出结果可以看出,promise中 构造函数是同步执行,进入then或者catch后则是异步执行。

再详细说一下promise的用法:

then可以连续使用,前一个then中的返回值 是下一个then的输入值,请看示例代码:




    
    
    
    Document


    

输出结果:

JavaScript 异步 setTimeout promise async await_第3张图片

或者 拿到promise对象然后执行then:

 

输出结果:

JavaScript 异步 setTimeout promise async await_第4张图片

3,async  用法简单,在定义函数是 函数名称前 加上async关键字即可,async函数返回一个promise,但是此时是同步执行,请看实例代码:

 

输出结果如下:

JavaScript 异步 setTimeout promise async await_第5张图片

由打印结果可以看出,代码是顺序执行的。

函数返回值再调用then即可开始异步执行。

    

打印结果如下:

JavaScript 异步 setTimeout promise async await_第6张图片

async 和 await 

await 就是等待异步处理完成,然后向下执行代码。

    function testAwait() {
            return new Promise((resolve) => {
                setTimeout(function () {
                    console.log("testAwait");
                    resolve();
                }, 1000);
            });
        }

        async function helloAsync() {
            testAwait();
            console.log("helloAsync");
        }
        helloAsync();

执行结果:

JavaScript 异步 setTimeout promise async await_第7张图片执行结果很明显值先执行

 

  console.log("helloAsync"); 再执行  console.log("restawait");

如果加上await 执行顺序发生变化

JavaScript 异步 setTimeout promise async await_第8张图片

执行结果

 JavaScript 异步 setTimeout promise async await_第9张图片

 

你可能感兴趣的:(javascript)