一、兼容情况

说到ECMAScript6,顺便提一下ECMAScript5,先看一下ES5的兼容情况。ES5浏览器支持情况:
Opera 11.60;Internet Explorer 9*;Firefox 4;Safari 5.1**;Chrome 13
* IE9不支持严格模式 — IE10 添加
** Safari 5.1 仍不支持 Function.prototype.bind, 尽管Function.prototype.bind现在已经被

Webkit所支持。

具体ES5、ES6各浏览器支持情况可以查看
ECMAScript5:http://kangax.github.io/compat-table/es5/
ECMAScript6:http://kangax.github.io/compat-table/es6/

二、兼容方法

针对ES6的兼容性问题,很多团队为此开发出了多种语法解析转换工具,把ES6语法转换成ES5。

比较通用的工具方案有babel,traceur,jsx,es6-shim等。
此外,浏览器自身也加快速度兼容ES6的新特性,其中对ES6新特性最友好的是Chrome和Firefox

浏览器。在使用ES6时,先不用引入任何东西,去测试,因为现在浏览器已经支持部分ES6功能,有的

不需要转码,转码反而错误。
我们用下面的代码去测试浏览器是否兼容ES6语法const
<script>
const Name = '张三';//使用新增的关键字:const声明常量
alert(Name);
</script>

正常运行,会弹出“张三”,如果报错我们就知道是浏览器出现了兼容问题。当浏览器不支持

ES6时,再用Babel和Traceur对ES6进行转码。

三、使用Babel来兼容

使用npm来安装babel,npm是和Nodejs一起安装的包管理工具,新版的nodejs已经继承了npm,我

们只要安装nodejs即可。在node官网下载后缀为msi的最新安装包,下载后找到文件双击运行,点击下

一步安装即可,期间可以自定义选择安装的位置,默认是C:\ProgramFiles\。启动命令提示符窗口,

输入“node --version”来检测当前node的版本,当有版本号显示说明Node成功安装。
下面我们用npm安装babel,启动命令提示符窗口并且输入:npm install babel-core@5,然后回

车,安装成功后,打开目录:C:\Users\Administrator\node_modules\babel-core,在这个目录里面

我们找到babel的浏览器版本browser.js(未压缩版)和browser.min.js(压缩版)。把browser.min.js

引入(文件位置的路径要确保正确)。并且设置第二个script标签的type为”text/babel”。
<script src="browser.min.js"></script>
<script type="text/babel">
const Name = '张三';
alert(Name);
</script>

四、使用Traceur转码器直接插入网页的方法来转码ES6

在网页头部加载Traceur库文件。
<script src="https://google.github.io/traceur-compiler/bin/traceur.js"></script>
<script src="https://google.github.io/traceur-compiler/bin/BrowserSystem.js"></script>
<script src="https://google.github.io/traceur-compiler/src/bootstrap.js"></script>
<script type="module">
const Name = '张三';
alert(Name);
</script>

1.traceur:是由Google出的编译器,可以将ES5编译成ES6
2.bootstrap:是一个引导程序(与响应式的bootstrap不同)
3.需要将traceur.js和bootstrap.js下载下来,引入到当前文件中即可
4.最后的script标签的type属性的值是module,而不是text/javascript。这是Traceur编译器识别

ES6代码的标志,编译器会自动将所有type=module的代码编译为ES5,然后再交给浏览器执行。

五、另外还有Babel转码器的其他使用方法,Traceur的命令行转换方法和Node.js环境的用法,这里的

方法只是作为一个学习的入门案例,起到抛砖引玉的作用,让新手们能对ES6的兼容问题和转换工具

有个认识,并没有覆盖所有兼容方案的介绍,希望大家随着对ES6越来越深入学习,对转换工具的掌

握也越来越全面和熟练。

简单搭建ES6的环境的更多相关文章

  1. 搭建ES6运行环境

    当ES5还没有完全普及时,ES6就接踵而来了,2015年6月17日,ECMAScript 6发布正式版本,即ECMAScript 2015,我们也简称它为ES6或ES2015.在发布之后的将近一年内, ...

  2. 为何要搭建ES6开发环境,如何搭建ES6开发环境?

    1.ES6需要搭建开发环境,原因是现在的Chrome浏览器已经支持ES6了,但是有些低版本的浏览器还是不支持ES6语法的,这就需要我们把ES6的语法自动转变成ES5的语法.   2.开始搭建环境   ...

  3. docker的简单搭建(java/tomcat 环境)

    1.一副图简单了解下docker的布局,它是虚拟的,docker分为私服.镜像.容器三个模块 一般从私服pull镜像,镜像run一个容器,我们把容器作为一个虚拟服务,里面可以独立运行进程有独立的内网I ...

  4. 轻松搭建ES6开发环境

    首先,你要自行查阅什么是ES6和ES5.javascript有什么关系,为什么要编译ES6.废话不多说,just go! 第一步:创建项目并让它成为npm可以管理的仓库. 新建一个项目,名字假设为te ...

  5. 构建前端第8篇之---Webstom搭建ES6运行环境

    张艳涛 写于2021-1-22 一.在有webstorm和node.js前提下,安装全局的babel npm install babel-cli babel-eslint -g 二.在terminal ...

  6. webstorm 搭建es6开发环境

    本文转自:http://www.jianshu.com/p/26601581e152 1:新建一个Empty Project项目es6 ,然后在src目录下新建了一个es.js: 2:打开设置pref ...

  7. 前端 - 使用gulp搭建es6运行环境

    1.创建一个项目目录2.全局安装Traceur,在控制台输入 npm install -g traceur3.打开项目目录,安装gulp以及gulp-traceur插件 npm install -g ...

  8. 搭建ES6开发环境

    https://github.com/IOJINDD/ES6-dev 在gulpfile最后一行加上: gulp.task('default', ['compile-es6', 'pack-js', ...

  9. es6开发环境搭建,babel 将es6转化成es5

    工欲善其事,必先利其器.所以我们第1节就是搭建一个基本的ES6开发环境.现在的Chrome浏览器已经支持ES6了,但是有些低版本的浏览器还是不支持ES6的语法,这就需要我们把ES6的语法自动的转变成E ...

随机推荐

  1. Linux正则表达式语法

    基本组成部分: 正则表达式的基本组成部分. 正则表达式 描述 示例 \ 转义符,将特殊字符进行转义,忽略其特殊意义 a\.b匹配a.b,但不能匹配ajb,.被转义为特殊意义 ^ 匹配行首,awk中,^ ...

  2. COM组件转换为.NET元数据2

    上一篇通过命令的方式实现COM组件与.NET元素的转换.这次直接在VS中转换. 以下为步骤:

  3. 自己动手写http服务器——线程池(一)

    创建一个线程池,每有一个连接对象就将它添加到工作队列中,线程池中的线程通过竞争来取得任务并执行它(它是通过信号量实现的). //filename threadpool.h #ifndef THREAD ...

  4. python学习第一天基础篇

    学习背景:决定开始学习python之前,因为公司基本都是微软系统,所以很少碰到linux系统,机缘巧合接到了一个项目是使用shell对mysql进行backup,因为公司唯一的系统工程师是微软在行,对 ...

  5. PushMeBaby 使用

    github 下载地址 https://github.com/stefanhafeneger/PushMeBaby 1.执行假设报错,那么导入CoreServices.framawork 替换这句 # ...

  6. Android学习笔记(10).布局管理器

    布局管理器的几个类都是ViewGroup派生的,用于管理组件的分布和大小,使用布局管理器能够非常好地解决屏幕适配问题. 布局管理器本身也是一个UI组件,布局管理器能够相互嵌套使用,以下是布局管理器的类 ...

  7. 【VS2017新特性】在VS中调试javascript脚本

    1   概述 VS2017可以调试JS,本篇文章简要概述VS2017关于启用和关闭VS调试功能. 2   具体内容 当开启VS2017JS调试功能时,我们用VS2017打开解决方案时,会出现如下界面: ...

  8. 【Sqlserver系列】【转载】事物与锁

    1   概述 本篇文章简要对事物与锁的分析比较详细,因此就转载了. 2   具体内容 并发可以定义为多个进程同时访问或修改共享数据的能力.处于活动状态而互不干涉的并发用户进程的数量越多,数据库系统的并 ...

  9. Docker 搭建 etcd 集群

    阅读目录: 主机安装 集群搭建 API 操作 API 说明和 etcdctl 命令说明 etcd 是 CoreOS 团队发起的一个开源项目(Go 语言,其实很多这类项目都是 Go 语言实现的,只能说很 ...

  10. linux 安装tensorflow(gpu版本)

    一.安装cuda 具体安装过程见我的另一篇博客,ubuntu16.04下安装配置深度学习环境 二.安装tensorflow 1.具体安装过程官网其实写的比较详细,总结一下的话可以分为两种:安装rele ...