阮一峰的博客
http://es6.ruanyifeng.com/
一 ES6简介
ECMAScript 6.0(以下简称 ES6)是 JavaScript 语言的下一代标准,已经在2015年6月正式发布了。
2011年,ECMAScript 5.1版发布后,就开始制定6.0版了。
因此,ES6 这个词的原意,
就是指 JavaScript 语言的下一个版本。
二 检查浏览器是否支持ES6的方法
http://ruanyf.github.io/es-checker
三 语法介绍
(一) let和const的使用
1.1 let 关键字的使用
1.2 let和 var的区别案例
1.3 ES6的代码块作用域
1.4 let 不存在变量的提升定义
1.5 let的暂时性死区
1.6 const 关键字的使用
1.7 const定义常量的使用
1.8 const的本质
const实际上保证的,并不是变量的值不得改动,而是变量指向的那个内存地址不得改动。对于简单类型的数据(数值、字符串、布尔值),值就保存在变量指向的那个内存地址,因此等同于常量。但对于复合类型的数据(主要是对象和数组),变量指向的内存地址,保存的只是一个指针,const只能保证这个指针是固定的,至于它指向的数据结构是不是可变的,就完全不能控制了。因此,将一个对象声明为常量必须非常小心。
2.0 ES6 声明变量的六种方法
2.1 ES6 的顶层对象的属性
注意let和const变量 不添加到window中
(二) 变量的解构赋值
1.1 数组的解构
let [a,b] = [100,200];
1.2 对象的解构
注意: 对象的解构没有顺序
let { bar, foo } = { foo: "aaa", bar: "bbb" };
1.3 数值和布尔值的解构赋值
1.4 函数参数的解构赋值 (函数会说明)
1.5 圆括号问题
(三) 字符串扩展
1.1 字符的 Unicode 表示法
百度搜索:汉字字符编码
http://www.mytju.com/classCode/tools/encode_gb2312.asp
http://tool.chinaz.com/Tools/Unicode.aspx
1.2 codePointAt()
1.3 String.fromCodePoint()
1.4 字符串的遍历器接口
for...of的使用 和for...in的区别
1.5 charAt方法 ES5新增的方法
1.6 includes(), startsWith(), endsWith()
1.7 repeat()
1.8 模板字符串(重点)
// ES6字符串教程中
// 有箭头函数的写法和...参数的写法
1.8.1 字符串模板的来源是使用+的不方便
'name'+name+"age is"+age
1.8.2 字符串的插值采用${name}的方式实现
1.8.3 标签模板 tagged template
function tag(stringArr, value1, value2){
// ...
}
// 等同于
function tag(stringArr, ...values){
// ...
}
(四) 函数的扩展
1.1 函数参数的默认值
ES6新添加的函数默认值
1.2 rest参数
ES6 引入 rest 参数(形式为"...变量名"),用于获取函数的多余参数,这样就不需要使用arguments对象了
1.3 扩展运算符
可以看做前面的rest参数的逆运算
扩展运算符(spread)是三个点(...)
将一个数组转为用逗号分隔的参数序列。
注意:三个点(...)用在不同的地方表示的意义不一样
1.4 严格模式
1.4.1 从 ES5 开始,函数内部可以设定为严格模式。
1.4.3 ES2016 做了一点修改,规定只要函数参数使用了默认值、解构赋值、或者扩展运算符,那么函数内部就不能显式设定为严格模式,否则会报错。
1.5 name 属性
1.6 箭头函数
1.7 绑定 this
(五) 数值Number的扩展
1.1 二进制和八进制表示法
1.2 Number.isFinite(), Number.isNaN()
1.3 Number.parseInt(), Number.parseFloat()
1.4 Number.isInteger()
四 Babel介绍使用
1.1 后缀名称为.babelrc文件
添加:
{
"presets": ["env"]
}
1.2 安装babel的包文件
npm install --save-dev babel-cli babel-preset-env
1.2 运行测试文件01example.js
1.3 babel测试文件
babel 01example.js
1.4 babel -d 测试输出文件
babel 01example.js --out-file 01result.js
或者
babel 01example.js -o 01result.js
1.5 babel 的配置环境介绍
https://excaliburhan.com/post/babel-preset-and-plugins.html