1. What are microtasks? 2. What are the macro tasks?
3. Case<script> console.log(1) setTimeout(()=>{ console.log("2") },0) Promise.resolve().then(()=>{ console.log('3') }) console.log(4) </script> We found that the order of printing is Why is it in this order? Print 1-4 first. There is definitely no problem. Why is 3 printed first and then 2? Because 3 is 2 is Microtasks are executed earlier than macrotasks. So 3 is executed first and then 2 3.1 Conclusion
4. Code Examples<body> <div id="app"></div> <script> // This section is DOM rendering let app=document.getElementById("app") let cont='<p>I am a p tag</p>' app.append(cont) // DOM rendering ends console.log(1) setTimeout(()=>{ console.log("2") alert('setTimeout2') },0) Promise.resolve().then(()=>{ console.log('3') alert('3') }) console.log(4) </script> </body> 4.1 Code AnalysisExecution analysis of the above code: You must execute Then according to the micro task first and then the macro task It outputs 3 and then pops up 3 Then it says output 2 and pops up Because there is a So then comes So after outputting Then output 2 and then 4.2 Conclusion and Application ScenariosMicrotask>DOM rendering>Macrotask See the following example Application scenarios of this conclusion We have all done echarts. We know when rendering echarts. The node can only be rendered after the DOM of the page is rendered. So some friends will put the request timing in the monitored() life cycle This ensures that the returned data can be rendered normally on the page. In fact, based on the above conclusion. You can request data in create. When I came back. The DOM is definitely rendered. Because the request is a macro task. The execution time of the macro task is after DOM rendering. This is the end of this article about the details of macrotasks and microtasks in You may also be interested in:
|
<<: A few front-end practice summaries of Alipay's new homepage
Result: Implementation code: Need to be used with...
(?i) means do not match case. Replace all uppercas...
This article summarizes the notes for installing ...
IIS7 Download the HTTP Rewrite module from Micros...
This article refers to the work of 51CTO blog aut...
Running environment, Idea2020 version, Tomcat10, ...
Table of contents System update configuration Cha...
Read uncommitted example operation process - Read...
Table of contents Reactive Function usage: toRef ...
Since the team is separating the front-end and ba...
Preface DISTINCT is actually very similar to the ...
1. readonly read-only attribute, so you can get th...
Preface: MySQL is a relational database managemen...
As we all know, the CSS position absolute is set ...
1. In the previous chapter, we learned that we ca...