docs: 文档更新 前端工程化/Node.js

This commit is contained in:
ZiuChen 2023-02-07 23:31:06 +08:00
parent 7cdca1d4cb
commit 70f9f602cf
3 changed files with 51 additions and 2 deletions

View File

@ -33,7 +33,8 @@ export default defineConfig({
items: [
{ text: 'JavaScript基础', link: '/note/JavaScript' },
{ text: 'CSS基础', link: '/note/CSS' },
{ text: 'JavaScript进阶', link: '/note/JavaScriptEnhanced' }
{ text: 'JavaScript进阶', link: '/note/JavaScriptEnhanced' },
{ text: '前端工程化', link: '/note/Front-end Engineering' }
]
},
{
@ -73,7 +74,8 @@ export default defineConfig({
items: [
{ text: 'JavaScript基础', link: '/note/JavaScript' },
{ text: 'CSS基础', link: '/note/CSS' },
{ text: 'JavaScript进阶', link: '/note/JavaScriptEnhanced' }
{ text: 'JavaScript进阶', link: '/note/JavaScriptEnhanced' },
{ text: '前端工程化', link: '/note/Front-end Engineering' }
]
}
],

Binary file not shown.

After

Width:  |  Height:  |  Size: 49 KiB

View File

@ -0,0 +1,47 @@
# 前端工程化
## Node.js
- 什么是Node.JS Node的应用场景
- JS代码执行
- Node的输入和输出
- Node的全局对象
### 什么是Node.js
Node.js是一个基于**V8 JavaScript引擎**的**JavaScript运行时环境**
- V8可以嵌入到任何C++应用程序中无论是Chrome还是Node.js事实上都嵌入了V8引擎来执行JavaScript代码
- 在Chrome浏览器中还需要解析、渲染HTML、CSS等相关渲染引擎另外还需要支持浏览器操作的API、浏览器自己的事件循环
- 在Node.js中我们也需要进行一些额外操作文件系统读写、网络IO、加密、压缩解压文件等
可以简单总结出Node.js和浏览器的区别
- Chrome浏览器
- Blink负责解析HTML文档遇到JavaScript标签时将内容交给V8引擎
- > Blink 是 Google Chrome 浏览器的渲染引擎V8 是 Blink 内置的 JavaScript 引擎
- 预分析检查语法错误但不生成AST树
- 生成AST语法分析、词法分析后生成抽象语法树AST
- AST 为每一行代码定义键值对。初始类型标识符定义 AST 属于一个程序,然后所有代码行将定义在主体内部,主体是一个对象数组。
- 生成字节码基线编译器Ignition将 AST 转换为字节码
- 生成机器代码:优化编译器 (Turbofan) 将字节码转换为优化的机器代码。另外,在逐行执行字节码的过程中,**如果一段代码经常被执行V8会直接将这段代码转换并保存为机器码**,下次执行不需要经过字节码,优化了执行速度
- Node.js
- 只处理JavaScript代码 内部V8引擎负责JS代码的执行
- JavaScript代码 -> V8 -> Node.js Bindings -> LibUV
- LibUV是使用**C语言编写的库**,提供了**事件循环、文件系统读写、网络IO、线程池**等等内容
![The Node.js System](Front-end Engineering.assets/The Node.js System.jpeg)
### Node.js的应用场景
- 前端开发的库都是以node包形式管理的
- npm yarn pnpm成为前端开发使用最多的工具
- 使用Node.js作为Web服务器开发、中间件、代理服务器
- 借助Node.js完成前后端渲染的同构应用
- 编写脚本工具 构建项目 打包代码等
- Electron桌面应用程序