原因:为了浏览器兼容,以及为了在node.js环境可以顺畅运行应用程序。es6作为js的新规范,加入了很多新的语法和api,但现代浏览器对es6新特性支持度不高,所以需将es6代码转为es5代码;只需在项目中安装和配置好babel工具即可。
本教程操作环境:windows7系统、ecmascript 6版、dell g3电脑。
为什么要将es6转为es5?
简单答案就是:为了浏览器兼容,以及为了在 node.js 环境可以顺畅运行应用程序。
es6作为js的新规范,加入了很多新的语法和api,而市面上的浏览器并没有全部兼容,所以需要将es6语法代码转为es5的代码。
现代浏览器对es6新特性支持度不高,所以要想在浏览器中直接使用es6的新特性就得借助别的工具来实现。
在 node.js 环境中,node 对 es6 的支持一直被诟病,到了 13 版本之后,才出了模块模式(在 package.json 中增加一句:“type”: “module”),但有些库仍然不支持 es6 语法。因此,如果你的 node.js 程序遇到不认识 es6 语法的时候,请使用 babel 转码一下也许就能解决问题。
怎么将es6转为es5?
用babel将es6转换成es5。
下面我们写出在命令行使用 babel 的过程,让你清楚转译过程的全部内容。
1. 在项目中安装 babel 的命令行工具
npm install -d babel-cli
2. 准备 es6 代码
通常我们把源代码放在 src 目录下,如果你没有现成的 es6 代码,那就在 src 目录下创建一个:
// src/example.jsclass hello { static world() { console.log('hello, world!'); }}hello.world();
3. 配置 babel
babel 是通过插件和预设值(preset)来转译代码(因此它可以转译的不只是 es6)。为了转译 es6 为 es5,我们只需要配置 env 预设值就可以了,安装这个插件:
npm install -d babel-preset-env
我们还需要一个配置文件,在项目根目录下创建文件:.babelrc,内容如下:
// .babelrc{ presets: [env]}
4. 创建 npm 命令
这一步不是必须的,因为前面已经配置好了,你可以直接执行命令:
babel src -d build
这样就会把 src 目录下的 javascript 代码转译成 es5,并存放在 build 目录下。
习惯上,我们将上门的命令放到 npm 命令中。在项目的 package.json 中,输入下面的内容:
scripts: { build: babel src -d build,},
这样你就可以使用下面的命令来转译 es6 代码:
npm run build
【相关推荐:javascript视频教程、web前端】
以上就是为什么要将es6转为es5的详细内容。