zoukankan      html  css  js  c++  java
  • 【原生】 微任务和宏任务

    <!DOCTYPE html>
    <html lang="en">
    <head>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <meta http-equiv="X-UA-Compatible" content="ie=edge">
        <title>Document</title>
    </head>
    <body>
        <script>
                //  事件驱动型语言
    
                // console.log("a");  
                // document.addEventListener("nihao",nihaoHandler);//侦听事件
                // var evt=new Event("nihao");   //新建事件
                // document.dispatchEvent(evt);
                // console.log("b");
    
                // function nihaoHandler(e){  //执行事件
                //     console.log("c");
                // }
    //事件是及时性的,打印结果是a  c   b  
    
    //下面代码运行结果是a  b   c ,这个事件不是及时执行的
    
                // console.log("a");
                // setTimeout(timeHandler,0);
                // console.log("b");
    
                // function timeHandler(){
                //     console.log("c");
                // }
    
    
                // console.log("a");
                // Promise.resolve().then(function(){
                //     console.log("b");
                // })//异步
                // console.log("c");
    
    //01是打印顺序,是微任务和宏任务
                console.log("a"); //01
                setTimeout(timeHandler,0);
                Promise.resolve().then(function(){
                    console.log("c");//03
                });
                console.log("d");//02
                function timeHandler(){
                    console.log("b");//04
                }//运行结果:a,d,c,b
    
    
                // 微任务和宏任务
                // 宏任务   setTimeOut,setInterval   当触发时放在下一个任务列的最前面执行
                // 微任务   Promise  当触发时,放在当前任务列的最后面执行
    
    
    // a i n j m b e d c k l f g h
    
            //    console.log("a");
            //    document.addEventListener("ab",abHandler);
            //    //1
            //    setTimeout(function(){
            //         console.log("b");
            //         document.dispatchEvent(new Event("ab"));
            //         Promise.resolve().then(function(){
            //             console.log("c");
            //             //4
            //             setTimeout(timeHanlder,0)
            //         });
            //         console.log("d");
            //    },0);
            //    new Promise(function(res,rej){
            //        console.log("i");//这个是同步执行的
            //        //2
            //        setTimeout(function(){
            //            console.log("k");
            //        },0)
            //        res();
            //    }).then(function(){
            //        console.log("j");
            //        //3
            //        setTimeout(function(){
            //            console.log("l")
            //        },0);
            //        Promise.resolve().then(function(){
            //            console.log("m");
            //        })
            //    });
            //    console.log("n");
            //    function abHandler(e){
            //        console.log("e");
            //    }
            //    function timeHanlder(){
            //        console.log("f");
            //        new Promise(function(reslove,reject){
            //            console.log("g");//同样同步执行
            //             reslove()
            //        }).then(function(){
            //             console.log("h");
            //        })
            //    }
    
    
    
    
            //    var a=3;
            //    Promise.resolve().then(function(){
            //         console.log(a+b);
            //         // 当前script标签任务列完成
            //         var div=document.querySelector("div");
            //         console.log(div);
            //    });
            //    var b=4;
    
            //    var div=document.createElement("div");
            //    document.body.appendChild(div);
        </script>
        <!-- <div></div> -->
    
    </body>
    </html>
    1、路在何方? 路在脚下 2、何去何从? 每个人都在探索,未来的方向在何处。如果说某些方向是世人已经公认的,那么就先按照公认的去走吧(ps:站在巨人的肩膀上看世界会清晰)。 如果说方向,当今世人还不清晰准确。那么就大胆往前走吧,对与错并不重要。心中的方向更加重要。
  • 相关阅读:
    map集合的见解、排序
    java mysql 数据类型对照
    spring 通过@Value 获取properties文件中设置了属性 ,与@Value # 和$的区别
    nginx中的超时设置,请求超时、响应等待超时等
    Linux配置多个Tomcat同时运行
    Socket TCP Server一个端口可以有多少个长连接?受到什么影响?linux最大文件句柄数量总结
    tomcat关闭后线程依然运行解决办法
    守护线程与非守护线程的区别
    SSM整合——spring4.*配置案例
    SSM事务——事务回滚如何拿到返回值
  • 原文地址:https://www.cnblogs.com/yuanjili666/p/11464701.html
Copyright © 2011-2022 走看看