JS 事件循环 mutate为什么打印在两个promise之间?


<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <div id="outer">
        <div id="inner"></div>
    </div>
    <script>
        var outer = document.querySelector('#outer');
        var inner = document.querySelector('#inner');

        new MutationObserver(function(a,b){ 
            console.log('mutate');
        }).observe(outer, {attributes: true, });

        function onClick(){
            console.log('click');
            setTimeout(function(){
                console.log('timeout');
            }, 0);
            Promise.resolve().then(function(){
                console.log('promise');
            });
            outer.setAttribute('data-random', Math.random());
        }
        inner.addEventListener('click', onClick);
        outer.addEventListener('click', onClick);
        inner.click();

        //控制台输出顺序
        // click
        // click
        // promise
        // mutate
        // promise
        // timeout
        // timeout
    </script>
</body>
</html>

MutationObserver,Promise.then是微任务,setTimeout宏任务,微任务和宏任务都是异步执行,主线程执行完(click)后,到微任务,再到宏任务。
同级别任务按照出现顺序先后执行,所以主线程先执行完inner的onclick事件后冒泡再到outer的click执行,

这样微任务序列为inner的promise.then,MutationObserver,外部的promise.then
宏任务就是inner的setTimeout,outer的setTimeout
有帮助或启发麻烦点个采纳【本回答右上角】,谢谢~~