IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> 前端春招面试,浏览器渲染详细过程,(V8,Layout)引擎解析 -> 正文阅读

[JavaScript知识库]前端春招面试,浏览器渲染详细过程,(V8,Layout)引擎解析

1.解析过程

  1. 解析->输入网址后被dns解析后的返回的html(包含html标签css样式)文件
  2. 解析html标签时,使用html parser进行解析,解析 css时使用 css parser 进行解析
  3. html被parser后生成Dom tree , css被 Parser后生成 style rules
  4. 合并生成的 Dom Tree和 Style Rules 生成Attachment
  5. 再将Attachment 解析成 Render Tree (渲染树), 其中 生成Render Tree的过程,使用到了 Layout engine (排版引擎)
  6. 将生成的Render Tree进行Patting渲染,进行显示(即我们在浏览器看到的页面)
    在这里插入图片描述

2.解析html时,出现script标签时

 会停止解析html,浏览器会去加载,并执行js文件。(所以一般情况下,script标签都会放到最后)

3.解析过程中对Dom的一些操作由谁来完成

在图中,可以看到在生成Dom数的时候,就已经进行了Dom的操作,操作dom的过程是由js引擎来做的

4.js引擎在编译js代码时,都做了什么(以V8引擎为例)

  1. 进行Parser (词法分析,语法分析)
  2. 生成抽象AST树
  3. AST通过Ignition(理解成解释器或者转化器)生成 bytecode(字节码),js实现跨平台的关键点
  4. 最后根据运行环境,自动将字节码转成对应的汇编代码->机器码,由cpu执行

5.Layout engine 的作用是什么?

根据界面的大小,进行界面尺寸的动态排版
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-01-28 11:49:07  更:2022-01-28 11:50:25 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/24 13:29:58-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码