在搭建es6开发环境之前,先简单介绍一下es6。

ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言的下一代标准,已经在2015年6月正式发布了。它的目标,是使得 JavaScript 语言可以用来编写复杂的大型应用程序,成为企业级开发语言。

我们为什么要使用es6?es6有什么优点?......,我会在后面写一个es6专题系列,来介绍es6的使用。本次分享的内容是 es6的开发环境搭建。

那么,你肯定又要问,问什么要搭建es的开发环境,上面不都说 es6是JavaScript 语言的下一代标准了嘛,我们平时写的js都不需要搭建环境,直接在浏览器里就能运行。

因为至今各大浏览器厂商所开发的 JavaScript 引擎都还没有完成对 ES2015 中所有特性的完美支持,如果直接使用的话,会报错的。

所以我们既想使用es6带来的新语法新特性,又想让现在的浏览器支持es6语法,于是乎像 babel、Traceur 等编译器便出现了。它们能将尚未得到支持的 ES2015 特性转换为 ES5 标准的代码,使其得到浏览器的支持。

这里我们就使用Babel把ES6编译成ES5。

建立工程目录

先建立一个项目的工程目录,并在目录下边建立两个文件夹:src和dist

  • src:书写ES6代码的文件夹,写的js程序都放在这里。
  • dist:利用Babel编译成的ES5代码的文件夹,在HTML页面需要引入的时这里的js文件。

编写index.html

文件夹建立好后,我们新建一个index.html文件。

<!DOCTYPE html>
<html lang="en"><head><title></title><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1"><script src="./dist/index.js"></script></head><body>Hello ECMA Script 6</body>
</html>

需要注意的是在引入js文件时,引入的是dist目录下的文件。

<script src="./dist/index.js"></script>

编写index.js

在src目录下,新建index.js文件。这个文件很简单,我们只作一个a变量的声明,并用console.log()打印出来。

let a=1;
console.log(a);

我们用了let声明,这里let是ES6的一种声明方式,接下来我们需要把这个ES6的语法文件自动编程成ES5的语法文件。

初始化项目

在安装Babel之前,需要用npm init先初始化我们的项目。打开终端或者通过cmd打开命令行工具,进入项目目录,输入下边的命令:

npm init -y

-y代表全部默认同意,就不用一次次按回车了。命令执行完成后,会在项目根目录下生产package.json文件。

{"name": "es6","version": "1.0.0","description": "","main": "index.js","scripts": {"test": "echo \"Error: no test specified\" && exit 1"},"keywords": [],"author": "","license": "ISC"
}

可以根据自己的需要进行修改,比如我们修改name的值。

全局安装Babel-cli

在终端中输入以下命令,如果你安装很慢的话,可以使用淘宝镜像的cnpm来进行安装。安装cnpm的方法,大家自己百度吧。

cnpm install -g babel-cli

虽然已经安装了babel-cli,只是这样还不能成功进行转换,如果你不相信可以输入下边的命令试一下。

babel src/index.js -o dist/index.js

你会发现,在dist目录下确实生产了index.js文件,但是文件并没有变化,还是使用了ES6的语法。因为我们还需要安装转换包才能成功转换,继续往下看吧。

本地安装babel-preset-es2015 和 babel-cli

cnpm install --save-dev babel-preset-es2015 babel-cli

安装完成后,我们可以看一下我们的package.json文件,已经多了devDependencies选项。

"devDependencies": {"babel-cli": "^6.24.1","babel-preset-es2015": "^6.24.1"}

新建.babelrc

在根目录下新建.babelrc文件(注意,以点开头的文件是隐藏文件,需要在linux环境通过命令创建),并打开录入下面的代码

{"presets":["es2015"],"plugins":[]
}

这个文件我们建立完成后,现在可以在终端输入的转换命令了,这次ES6成功转化为ES5的语法。

babel src/index.js -o dist/index.js

简化转化命令

在学习vue 的时候,可以使用npm run build 直接利用webpack进行打包,在这里也希望利用这种方式完成转换。打开package.json文件,把文件修改成下面的样子。

{"name": "es6","version": "1.0.0","description": "","main": "index.js","scripts": {"build": "babel src/index.js -o dist/index.js"},"keywords": [],"author": "","license": "ISC","devDependencies": {"babel-cli": "^6.24.1","babel-preset-es2015": "^6.24.1"}
}

修改好后,以后我们就可以使用 npm run build 来进行转换了。

这样,一个简单的基本的编译环境就OK了。

转载于:https://www.cnblogs.com/zhouyangla/p/7076292.html

ES6的开发环境搭建相关推荐

  1. ES6(一)ES6的开发环境搭建(es6转码为es5)

    写在最前面 往后陆续更新EXMA script 6的文章,都是之前工作的积累和网上搜索总结后自己再重新操手一遍,为了以后工作的需要,有理解的不到位的地方请小伙伴多多指正,共同进步! es6的优点(题外 ...

  2. webpack+ES6+less开发环境搭建(附带视频教程)

    webpack是什么https://cnodejs.org/topic/571f4e785a26c4a841ecbd7c Webpack 是一个模块打包器.它将根据模块的依赖关系进行静态分析,然后将这 ...

  3. vuejs项目开发环境搭建(ESlint安装)

    vuejs项目开发环境搭建(ESlint安装) vuejs项目开发环境搭建,有时候需要安装ESlint! eslint对ES6语法支持更好,可以通过eslint在团队开发中快速统一ES6的语法,精简代 ...

  4. Android环境搭建和Android HelloWorld—Android开发环境搭建

    Android_Android开发环境搭建-搭建Android的开发环境 1.我考虑先下载JDK7.0,在JDK的安装中,考虑一般SDK都是向上兼容的,于是选择了最高的版本7.0 这里是我总结的详细的 ...

  5. qt工程在linux系统里颜色显示错误_【飞凌嵌入式RK3399开发板试用体验】+QT开发环境搭建测试(二)...

    作者:飞扬的青春 在拿到开发板之后,已经体验了Android操作系统,接下来就是体验Linux下的开发,本次以QT的一个小案例来测试下. 首先是自己先搭建了一个Ubuntu18.04的虚拟机,使用真机 ...

  6. Go:分布式学习利器(1) -- 开发环境搭建 + 运行第一个go程序

    文章目录 为什么要学习 go 开发环境搭建 -- MAC 运行第一个go程序 go 函数的返回值设置 go 函数的命令行参数 为什么要学习 go 在如下几个应用场景的需求下产生了go: 超大规模分布式 ...

  7. 智能合约开发环境搭建及Hello World合约

    如果你对于以太坊智能合约开发还没有概念(本文会假设你已经知道这些概念),建议先阅读入门篇. 就先学习任何编程语言一样,入门的第一个程序都是Hello World.今天我们来一步一步从搭建以太坊智能合约 ...

  8. iPhone开发环境搭建全过程 iPhone手机开发内容,中文手册

    http://3g.edu.csdn.net/kecheng/iphone.html  iPhone手机开发内容 http://www.docin.com/p-34874880.html# iPhon ...

  9. python搭建numpy_python开发环境搭建及numpy基本属性-【老鱼学numpy】

    目的 本节我们将介绍如何搭建python的开发环境以及numpy的基本属性,这样可以检验我们的numpy是否安装正确了. python开发环境的搭建 工欲善其事必先利其器,我用得比较顺手的是Intel ...

最新文章

  1. Excel随机选取指定数据
  2. Yaas上传附件的技术实现
  3. java操作mongodb(连接池)(转)
  4. python向CSV文件写内容
  5. maven单元测试报java.lang.IllegalStateException: Failed to load ApplicationContext
  6. “System.Exception: System.Data.OracleClient 需要 Oracle 客户端软件 8.1.7 或更高版本” 的解决方案...
  7. windows无法完成格式化U盘的几种终极解决办法
  8. Cocos Creator 3D 摇杆控制器一种简单实现!
  9. 目前主要的计算机汉字输入方法是什么,[计算机汉字输入方法.ppt
  10. 【太经典】如果有人问你数据库的原理,叫他看这篇文章
  11. SSR、SSE、SST、判定系数(可决系数、拟合优度)的计算公式
  12. COSO内部控制框架
  13. C#,CAD二次开发,基于参考面参考点计算一个点的坐标
  14. python基于PHP+MySQL的在线音乐点歌系统
  15. nuvoton uboo2013引导流程 2 - spl
  16. 游戏开发 数据库ID设计 ID生成器
  17. UniPro助力半导体企业之低代码平台篇:高效协同快速响应
  18. 这些响应式网页测试工具确保你的设计万无一失
  19. vscode中tab键无效怎么办
  20. 使用Bootstrap做轮播图

热门文章

  1. 【Java 基础】枚举、包装类、Math、Radnom、UUID、格式化、DecimalFormat、高精度计算(BigDecimal)
  2. 校招刷题---java选择题笔记01
  3. Thinkphp查询数据转成layui的展示格式
  4. 7zip和winrar命令行备份
  5. python动态页面元素爬取_python动态爬取网页
  6. 探索数据可视化,业务数据是核心
  7. 数据分析学习笔记—python数据类型与数据容器
  8. 可变悬挂与空气悬挂的区别_案例分析:宝马7系F02左后空气悬挂下趴检测与维修...
  9. python复杂网络全局效率计算_python复杂网络库networkx:算法
  10. Currency Exchange(判断有无正环)