首页 > 其他分享 >袁老师大师课笔记

袁老师大师课笔记

时间:2024-02-03 13:45:22浏览次数:18  
标签:浏览器 渲染 队列 老师 DOM 笔记 引擎 CSS 大师

浏览器是如何工作的?

浏览器是一个复杂的软件,其主要功能是获取并展示互联网上的信息。以下是浏览器的基本工作流程:

  1. 用户输入URL:用户在浏览器的地址栏中输入一个网址,也就是URL(Uniform Resource Locator,统一资源定位符)。
  2. DNS查询:浏览器通过DNS(Domain Name System,域名系统)查询将输入的网址转化为IP地址。DNS就像是一个电话黄页,将易于记忆的网址转化为计算机可以理解的IP地址。
  3. 建立TCP连接:浏览器通过TCP(Transmission Control Protocol,传输控制协议)与服务器建立连接。这个过程包括“三次握手”,以确保客户端和服务器都能发送和接收数据。
  4. 发送HTTP请求:浏览器通过已经建立的TCP连接发送一个HTTP请求到服务器。这个请求可能是一个GET请求,要求服务器返回某个网页的内容。
  5. 服务器处理请求:服务器接收到浏览器的请求后,会查找并处理这个请求。这可能涉及到运行一些服务器端脚本,查询数据库,或者只是简单地返回请求的文件。
  6. 返回HTTP响应:服务器处理完请求后,会返回一个HTTP响应。这个响应通常包含了请求的网页的HTML代码,也可能包含一些其他的数据,如CSS文件,JavaScript文件,或者图片等。
  7. 解析和渲染页面:浏览器接收到服务器的响应后,会开始解析HTML代码,并根据CSS和JavaScript来渲染页面。这个过程由浏览器的渲染引擎完成,它会把HTML,CSS,和JavaScript转化为用户可以看到的网页。
  8. 关闭TCP连接:当浏览器完成页面的加载和渲染后,它会关闭与服务器的TCP连接,除非服务器或者浏览器决定保持这个连接以便后续的请求。

以上就是浏览器的基本工作流程。需要注意的是,现代的浏览器都有很多优化和特性,如缓存,预加载,异步加载等,这些都可以提高网页的加载速度和用户体验。但是,这些优化和特性并不会改变浏览器的基本工作流程。

浏览器的渲染引擎是如何工作的?

浏览器的渲染引擎是负责将HTML、CSS和JavaScript代码转化为用户可以看到的可视化界面的关键组件。以下是渲染引擎的基本工作流程:

  1. 解析HTML

    • 渲染引擎首先解析HTML文档,将其转化为DOM(Document Object Model,文档对象模型)树。DOM树是一个节点树,它代表了文档的结构,使得开发者能够改变文档的内容和样式。
  2. 解析CSS

    • 与此同时,渲染引擎也会解析外部和内部的CSS样式表,并将其转化为CSSOM(CSS Object Model,CSS对象模型)。
    • CSS解析器会计算出DOM中每个节点的样式信息。
  3. 合并DOM和CSSOM

    • 渲染引擎将DOM和CSSOM结合起来,生成一个渲染树(Render Tree)。渲染树只包含需要渲染的节点(例如,由于CSS隐藏属性而不可见的DOM元素将不会出现在渲染树中)。
  4. 布局

    • 一旦渲染树构建完成,渲染引擎会开始布局(Layout)过程,也就是计算每个元素的大小和位置。这个过程涉及到盒模型的应用、相对和绝对定位的计算等。
  5. 绘制

    • 在布局完成后,渲染引擎将遍历渲染树,并使用UI后端层将每个节点绘制到屏幕上。这个过程涉及到图形的绘制、颜色的填充、文本的渲染等。
  6. 合成与渲染

    • 在绘制阶段后,有些浏览器会有额外的步骤,如合成(Compositing),将多个层合并到一个屏幕上。这通常涉及到硬件加速,以提高渲染性能。
  7. JavaScript的介入

    • JavaScript可以在任何时候介入这个过程,通过DOM API改变DOM树的结构,或通过CSSOM API改变样式信息,这都将导致渲染树的重新构建和布局的重新计算,最终影响到绘制过程。
  8. 重排(Reflow)与重绘(Repaint)

    • 当DOM的变化影响到元素的几何属性(宽和高)时,浏览器需要重新计算元素的几何属性,然后再进行绘制,这个过程叫做重排。
    • 当DOM的变化仅仅是影响元素的外观、风格而非几何属性时(例如改变文字颜色、背景色等),此时只需重绘即可。

现代浏览器的渲染引擎还包含很多优化技术,如异步渲染、渲染队列、请求动画帧等,以提高渲染性能和响应速度。同时,浏览器也在不断地更新和改进渲染引擎,以支持新的Web标准和提高用户体验。

JS的事件循环

  • 事件循环又叫做消息循环,是浏览器渲染主线程的工作方式。
  • 在Chrome的源码中,它开启一个不会结束的for循环,每次循环从消息队列中取出第一个任务执行,而其它线程只需要在合适的时候将任务加入到队列末尾即可。
  • 过去把消息队列简单分为宏队列和微队列,目前已无法满足复杂的浏览器环境,取而代之的是一种更加灵活多变的处理方式。
    根据W3C官方的解释,每个任务有不同的类型,不同任务可以有不同的任务队列。不同任务队列有不同的优先级,在一次事件循环中,有浏览器决定取哪一个队列的任务。但浏览器必须有一个微队列,微队列的任务必须具有最高优先级,必须优先调度执行。
    例:
  1. 微任务 Promise.resolve().then(fn)
  2. 用户交互任务
  3. 网络任务

JS中计时器可以做到精确计时么?为什么?

  1. 受事件循环的影响,计时器的回调函数只能在主线程空闲时执行,因此带来误差
  2. 按照W3C的标准,浏览器实现计时器时,如果嵌套层级超过5层,则会带有4ms的最少时间,在计时时间少于4ms时,带来变差
    操作系统的计时函数本身就有少量偏差
  3. 计算机硬件没有原子钟,无法做到精确计时

JS 单线程 事件循环 异步的关系

单线程是异步产生的原因
事件循环是异步的实现方式

标签:浏览器,渲染,队列,老师,DOM,笔记,引擎,CSS,大师
From: https://www.cnblogs.com/xs1987/p/18004584

相关文章

  • 狂神说Java Web学习笔记_JSP
    什么是JSPJSP(JavaServerPages):Java服务器端页面,和Servlet一样,用于动态web技术!写JSP就像在写HTML。它们之间不同的是,JSP页面里可以嵌入Java代码,提供动态数据。JSP原理IDEA使用tomcat服务器,会在tomcat中产生一个work目录;C:\Users\winner\AppData\Local\JetBrains\IntelliJId......
  • 动态规划做题笔记
    目录线性动态规划[NOIP1999提高组]导弹拦截尼克的任务双子序列最大和Flowers区间动态规划石子合并线性动态规划[NOIP1999提高组]导弹拦截第一问求最长不上升子序列,第二问可以考虑贪心,从左到右依次枚举每个导弹。假设现在有若干个导弹拦截系统可以拦截它,那么我们肯定选择......
  • 狂神说Java Web学习笔记_Cookie&Session
    Cookie,Session保存会话的两种技术,Cookie(客户端技术),Session(服务端技术)Cookie服务器端设置token,从客户端获取tokenCookie[]cookies=req.getCookies();//从客户端获取cookiecookie.getName();//获取cookie名字cookie.getValue();//获取cookie值Cookiecookie=newCoo......
  • 【学习笔记】Python 环境隔离
    目录前言venvvenv环境管理venv包管理virtualenv以及virtualenvwrapper安装virtualenvwrapper环境管理virtualenvwrapper包管理condaconda环境管理conda包管理总结参考资料Python作为最常用的脚本语言,有着非常丰富的第三方库,但是这也导致了Python的环境管理非常必要。......
  • 跟着王洋老师学编程 - 1.8 打字母游戏
    案例简述在一个300*400的窗体上,有10个随机产生的字母向下落,在键盘上敲字母,如果对了就消掉,初始成绩为1000分,每敲对一个字母加10分,如果字母落到屏幕下方,或者敲错扣100分。我的思路-创建一个窗体-创建一个字母画布类——继承画布类Panel、编写构造方法以初始化数据,实现多线程......
  • 运输层的TCP与UDP协议(学习笔记)
    一、运输层1.逻辑通信结构2.端口号、复用与分用二、TCP与UDP的区别1.概览图2.用户数据报协议UDP(UserDatagramProtocol)UDP面向应用层报文,可以在任何时候发起传输(无连接),向上层提供不可靠传输服务,即如果传输过程中出现误码,也不会触发重传。可以支持一对一、......
  • 人工智能(第3版) 第三章—学习笔记
    人工智能(第3版)第三章—学习笔记知情搜索(informedsearch,也称有信息搜索)利用启发式方法,通过限定搜索的深度或宽度来缩小问题空间。3.0引言介绍了本章的主要内容与几个重要的概念。3.1启发式方法乔治·波利亚——“启发式方法之父”​启发式方法的目的是大幅度减少到......
  • 寒假NOIP突破营笔记
    Day1枚举和搜索某些题的正解其实就是暴力,但加了一些优化三连击:暴力枚举即可DNA序列:\(O(nk)\)做法可以直接过;因为字符集大小只有\(4\),也可以使用哈希转为四进制统计\(O(n)\)栅栏:二分答案+搜索+剪枝k短路:A*:启发式搜索的一种,定义起点\(s\),终点\(t\),从起点(初始状态)开始的......
  • VITS课程学习笔记
    课程地址,https://www.bilibili.com/video/BV1wV411j7zG/?spm_id_from=333.788&vd_source=1eb6e5015a1f70daa97080d8ee786d5d VITS,VariationalInferencewithadversariallearningforend-to-endText-to-Speech论文,VITS:ConditionalVariationalAutoencoderwithAd......
  • 一些些数学的算法笔记
    好好好,直接进入正题(首先我们先要讲讲矩阵,矩阵你可以理解成\(n\timesm\)的一个二维数组,我们如下表示它:\[\begin{bmatrix}a_{1,1}&a_{1,2}&\cdots&a_{1,m}\\a_{2,1}&a_{2,2}&\cdots&a_{2,m}\\\vdots&\vdots&\ddots&\vdots\\a_{......