前言
相信大家对Babel已经不陌生了,Babel充斥在我们代码中的每个角落。比如:jsx转化成js,es6转化成es5…
一切需要代码转化的事都可以使用babel来做,但我们有没有想过,babel是怎么去进行代码转化的呢,它转化的过程中发生了什么,让我们一起来了解一下js的编译原理吧!
一、编译器和解释器
在了解之前,我们先来理解一下编译器和解释器的概念吧。
我们知道,我们所编写的代码是不能直接被机器识别的,需要转化成能被机器识别的机器语言。我们都知道,javascript是一门解释型语言,后端之王java是一门编译型语言,我们根据语言的执行流程可以分为解释型和编译型。我们来看看他们的区别吧。
- 解释型语言:需要将代码转换成机器码,但是和编译型的区别在于运行时需要转换。比较显著的特点是,解释型语言的执行速度要慢于编译型语言,因为解释型语言每次执行都需要把源码转换一次才能执行。
- 编译型语言:在代码运行前编译器直接将对应的代码转换成机器码,运行时不需要再重新翻译,直接可以使用编译后的结果。
目前市面上有很多种 JS 引擎,其中比较现代的 JS 引擎就是 V8,它引入了 Java 虚拟机和 C++ 编译器的众多技术,和早期的