body click js 委托_JS 事件循环

9ea1e832d8b80f5a8febe491ba50e9d7.png

进程 线程

  • CPU 分配资源的最小单位是进程,同一个时间内单个 CPU 只能运行一个进程,单个 CPU 一次只能运行一个任务
  • CPU 调度的最小单位是线程,一个进程里面包含多个线程。
  • 可以看看阮老师的这篇文章,进程与线程的一个简单解释

浏览器的进程

  • 浏览器主进程
    • 负责界面展示,用户交互,子进程管理,文件存取等
  • 插件进程
  • GPU 进程
    • 3d绘制
  • 网络进程
  • 渲染进程
    • 主要负责将 HTML, CSS, JavaScript 转换为用户可交互的网页,排版引擎 Blink 和
    • JavaScript 引擎 V8 就运行在渲染进程,默认每个 tab 一个渲染进程
    • 浏览器内核

浏览器的渲染流程

  • 解析 HTML 文件,生成 DOM tree;同时解析 CSS 文件以及样式元素中的样式数据,生成 CSS Rules
  • 构建 render tree:根据 DOM tree 和 CSS Rules 来构建 render tree,它可以让浏览器按照正确的顺序绘制内容
  • 布局(layout / reflow):计算各元素尺寸、位置。
  • 绘制(paint):绘制页面像素信息。
  • 浏览器将各层信息发送给 GPU,GPU 将各层信息合成(composite),显示在屏幕上。

浏览器内核

  • GUI 渲染线程
  • JS 引擎线程
    • JavaScript 是单线程的
    • GUI 渲染线程 与 JS 引擎线程是互斥的
    • JS 阻塞页面加载
  • 事件触发线程
  • 定时触发器线程
  • 异步 http 请求线程

宏任务,微任务

  • 事件轮询解释:事件轮询-阮一峰
  • JS 单线程
    • 单线程中如果同步执行的代码很慢,会让其它程度等待很长时间,这是同步阻塞。
    • 多线程会占用多倍的资源也会浪费多倍的资源,也不合理。
    • event_loop 是把需要等待的程序放到异步队列,主调用函数执行完之后监听,再执行异步队列,整个过程就是个不断的循环
    • JS 引擎遇到一个异步事件后并不会一直等待其返回结果,而是会将这个事件挂起,继续执行执行栈中的其他任务。当一个异步事件返回结果后,js会将这个事件加入与当前执行栈不同的另一个队列,我们称之为事件队列。被放入事件队列不会立刻执行其回调,而是等待当前执行栈中的所有任务都执行完毕, 主线程处于闲置状态时,主线程会去查找事件队列是否有任务。如果有,那么主线程会从中取出排在第一位的事件,并把这个事件对应的回调放入执行栈中,然后执行其中的同步代码…,如此反复,这样就形成了一个无限的循环。这就是这个过程被称为“事件环(Event Loop)”
  • 宏任务 宿主环境提供的异步方法 都是宏任务 script,ui 渲染,setTimeout,setInterval、setImmediate
  • 微任务 语言标准提供 promise,mutationObserver,process.nextTick,Object.observe(已废弃)
  • 默认先执行 script 脚本中的代码 -> 会清空微任务(将所有的微任务全部执行完) -> 渲染页面 -> 取出一个宏任务执行 -> 执行完毕后会再次情空微任务...

5ba0cc6178c29e64c3e10a28025074c0.png
微任务和宏任务执行
  • 浏览器黄色
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><!-- script是一个宏任务 --><script>document.body.style.background = 'red';console.log(1);// 在 setTimeout 执行前 会触发一次渲染Promise.resolve().then(()=>{console.log(2);document.body.style.background = 'yellow';});console.log(3);</script>
</body>
</html>
  • 按钮事件执行顺序
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><button id="button">点我啊</button><script>button.addEventListener('click', ()=>{console.log('listener1');Promise.resolve().then(()=>console.log('micro task1'));});button.addEventListener('click', ()=>{console.log('listener2');Promise.resolve().then(()=>console.log('micro task2'));});// 点击按钮之后的顺序// listener1// micro task1// listener2// micro task2// 一个个的函数来取 每次执行完 会先处理当前定义的微任务button.click(); // click1() click2()// listener1 listener2 micro task1 micro task2</script>
</body>
</html>
  • promise 和 setTimeout
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><script>Promise.resolve().then(() => {console.log('Promise1')setTimeout(() => {console.log('setTimeout2');}, 0);});setTimeout(() => {console.log('setTimeout1');Promise.resolve().then(() => {console.log('Promise2');});}, 0);// Promise1 setTimeout1 Promise2 setTimeout2</script>
</body>
</html>
  • 执行顺序
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><script>console.log(1);async function async () {console.log(2);await console.log(3); // Promise.resolve(console.log(3)).then(console.log(4))console.log(4);}setTimeout(() => {console.log(5);}, 0);const promise = new Promise((resolve, reject) => {console.log(6); // new Promise 代码会立即执行resolve(7);})promise.then(res => { // 第一个微任务console.log(res)});async (); console.log(8);// 1 6 2 3 8 7 4 5</script>
</body>
</html>
  • 执行顺序
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<body><script>console.log('script start');setTimeout(function() {console.log('setTimeout');}, 0);Promise.resolve().then(function() {console.log('promise1');}).then(function() {console.log('promise2');});console.log('script end');// script start// script end// promise1// promise2// setTimeout</script>
</body>
</html>
  • 一段变态的代码
// 1 7 6 8console.log('1');setTimeout(function() {console.log('2');process.nextTick(function() {console.log('3');});new Promise(function(resolve) {console.log('4');resolve();}).then(function() {console.log('5')});}, 0);process.nextTick(function() {console.log('6');});new Promise(function(resolve) {console.log('7');resolve();}).then(function() {console.log('8')});setTimeout(function() {console.log('9');process.nextTick(function() {console.log('10');});new Promise(function(resolve) {console.log('11');resolve();}).then(function() {console.log('12')});}, 0);

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/498968.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

django jsonresponse_利用 Django 动态展示 Pyecharts 图表数据的几种方法

本文将介绍如何在 web 框架 Django 中使用可视化工具 Pyecharts, 看完本教程你将掌握几种动态展示可视化数据的方法!Django 模板渲染1. 新建一个 Django 项目命令行中输入以下命令django-admin startproject pyecharts_django_demo创建一个应用程序python manage.py startapp d…

python网页登录验证码不显示_进网页需要验证码?不好意思,Python从来不惧各种验证码!...

今天要来说说滑动验证码了大家应该都很熟悉点击滑块然后移动到图片缺口进行验证现在越来越多的网站使用这样的验证方式为的是增加验证码识别的难度那么&#xff0c;对于这种验证码应该怎么破呢接下来就是见证神奇的时刻打开 b 站的登录页面可以看到登录的时候需要进行滑块验证按…

怎么调用新建模型里文章的内容_优雅地进行Tensorflow Lite模型转换

初涉知乎江湖&#xff0c;知道大佬很多&#xff0c;请温柔以待&#xff01;&#xff01;&#xff01;七日凌晨&#xff0c;谷歌连夜发布了有关于Tensorflow最新成果和技术&#xff0c;这应该是贾扬清离开脸书后另一个深度学习界令人惊呼的事件了吧&#xff01;&#xff08;旁白…

git add后取消_Git常用命令-总结

创建git用户$ git config --global user.name "Your Name"$ git config --global user.email "emailexample.com"初始化一个Git仓库&#xff0c;使用git init命令。添加文件到Git仓库&#xff0c;分两步&#xff1a;使用命令git add &#xff0c;注意&…

查看csv编码_[小O地图-数据] - 坐标转地址文字(逆地理编码)

小O地图是一款基于互联网地图进行地理数据处理、分析、图表的软件。致力为广大科研人员提供专业地图数据&#xff0c;用于科研及学习。小&#xff2f;地图提供将【经纬度坐标转换为地址】的功能&#xff0c;例如&#xff1a;将“116.359861, 39.917225” 转换为 “北京市西城区…

python自动化办公源码_python自动化办公:文件篇(自动整理文件,一键完成)

import os list_all[]#初始化一个空列表 for root ,dirs,files in os.walk(rC:UsersShineionDesktop新建文件夹): for name in files: file_pathos.path.join(root,name)#包含路径的文件 file_nameos.path.split(file_path)[-1] list_all.append(file_name) print(list_all)如果…

ocr中文数据集_CNOCR:测试集准确率最高98%,自带识别模型的中文OCR包

今天 Gitee 为大家介绍的是一款中文 OCR 包。大家都知道&#xff0c;训练模型是一件非常费时费力的事情&#xff0c;但今天这款项目已经自带训练好的识别模型&#xff0c;我们只需要下载下来使用即可&#xff0c;可以说是非常方便了&#xff0c;那么下面我们就去看看这个项目的…

sha算法源代码java_SHA算法Java实现

一 简介安全散列算法固定长度摘要信息二 SHA算法SHA-1、SHA-2(SHA-224、SHA-256、SHA384、SHA-512)三 SHA算法实现package com.imooc.security.sha; import java.security.MessageDigest; import java.security.NoSuchAlgorithmException; import java.security.Security; impo…

arraylist remove() java_执行ArrayList的remove(object)方法抛异常?

简介或许有很多小伙伴都尝试过如下的代码&#xff1a;然后会发现抛出java.util.ConcurrentModificationException异常&#xff0c;这是一个并发异常。那么这个到底是什么情况&#xff1f;首先需要介绍一下增强for循环增强for循环增强for循环是Java1.5后&#xff0c;Collection实…

centos gdb调试_gdb-miss-debuginfo

使用gdb调试core时候&#xff0c;提示Missing separate debuginfos的解决办法。错误提示错误提示信息如下&#xff1a;Missing separate debuginfos, use: debuginfo-install glibc-2.17-106.el7_2.8.x86_64 libaio-0.3.109-13.el7.x86_64 libgcc-4.8.5-4.el7.x86_64 libstdc-4…

怎么判断自己启动的线程是否执行完成 java_多线程?怎么用?

Java线程&#xff1a;概念与原理操作系统中线程和进程的概念现在的操作系统是多任务操作系统。多线程是实现多任务的一种方式。进程是指一个内存中运行的应用程序&#xff0c;每个进程都有自己独立的一块内存空间&#xff0c;一个进程中可以启动多个线程。比如在Windows系统中&…

mysql设置中文_Flask中MySQL预热

Flask和MySQL导读现在Flask已经学习到了类视图,它其实是这样一个关系FLask高级视图视图函数app.route\add_url_rule类视图蓝图blueprint(这个接下来要讲)结束蓝图后,接着就是Flask数据库的结合SQLAlchemy.在学习SQLAlchemy之前,希望和大家一起了解学习一下mysql这篇文章不涉及理…

html首行缩进2字符怎么设置_Word如何设置首行缩进2字符

在使用Word编写书籍或者文稿时&#xff0c;我们都会有个习惯将每个段落前面空两个字符&#xff0c;这样可以很好的方便读者阅读时分辨段落。有的人习惯用几个空格来代替&#xff0c;有的人习惯用空白字符V1来代替(像Word联盟网站上的每篇教程就是用V1来标记段落的)。其实在Word…

java 面试什么是类_Java 面试题代码类收集

long temp(int)3.9;System.out.println(temp);temp%2;System.out.println(temp);31View CodeJava里面类的方法名可以与类名一样&#xff0c;与构造函数的区别是方法有返回值&#xff0c;构造函数没有。public classUserInfo {publicUserInfo(){}publicString UserInfo(){return…

idea jdk配置_在IDEA中DEBUG Javac源码

背景在做JSR269的深度解析的时候&#xff0c;需要对javac的源代码进行单步调试并跟踪。因此在这里记录下具体的调试步骤。调试环境&#xff1a;OS: MacOS 10.14.5JDK&#xff1a;JDK_1.8IDEA: IntelliJ IDEA 2019.1.3下载Javac源码可以直接用JDK的github镜像仓库处下载&#xf…

jar中没有主清单属性_还在因 JDK 兼容问题发不同 JAR 包做兼容?MRJAR 了解一下?...

背景Java 9 版本中增强了Jar 包多版本字节码文件格式支持&#xff0c;也就是说在同一个 Jar 包中我们可以包含多个 Java 版本的 class 文件&#xff0c;这样就能做到 Jar 包升级到新的 Java 版本(新特性 API 使用)时不用强迫使用方为了使用新 Jar 包而升级自己的业务模块 Java …

java代码例子_程序员快速弄清Java异常体系,拒绝痛苦编程,开发效率加倍

知己知彼方能百战不殆,在小编初学Java时候特别怕程序报异常,经常会因为异常不知所措,相信这个问题应该是所有 初学者都会有的心理感受;如果你也有这种感受,那么只有一种解决方法: 迎难而上,攻克Java异常体系,长痛不如短痛,只要清楚了Java的异常体系,就不会再有这种感受了。下面…

java多条件判断_Java基础教程,第七讲,条件控制、循环语句、数组

学完此次课程&#xff0c;我能做什么&#xff1f;学完此次课程我们将掌握Java中的条件判断和多种循环语句&#xff0c;并且掌握数组的定义和初始化&#xff0c;以及几个常用的数组函数。学习此次课程&#xff0c;需要多久&#xff1f;10分钟课程内容和其他语言一样Java使用条件…

qq机器人源码_基于Springcloud+vue+oAuth2.0全家桶模拟商城项目源码分享

项目介绍功能点&#xff1a;模拟商城&#xff0c;完整的购物流程、后端运营平台对前端业务的支撑&#xff0c;和对项目的运维&#xff0c;有各项的监控指标和运维指标。技术点&#xff1a;核心技术为springcloudvue两个全家桶实现&#xff0c;采取了取自开源用于开源的目标&…

java静态页面我都做不出_Java高并发:静态页面生成方案

提升网站性能的方式有很多&#xff0c;例如有效的使用缓存&#xff0c;生成静态页面等等。今天要说的就是生成静态页面的方式。这个也是我近期一直在搞的一个问题&#xff0c;近期在做使用html servlet做个人网站&#xff0c;为什么是这2个东西呢&#xff1f;1、直接用servlet…