ES6语法

阮一峰的博客
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

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,835评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,598评论 1 295
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,569评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,159评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,533评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,710评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,923评论 2 313
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,674评论 0 203
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,421评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,622评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,115评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,428评论 2 254
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,114评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,097评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,875评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,753评论 2 276
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,649评论 2 271

推荐阅读更多精彩内容

  • 阮一峰的博客 http://es6.ruanyifeng.com/ 一 ES6简介 ECMAScript 6.0(...
    ai搞搞阅读 1,688评论 0 0
  • 以下内容是我在学习和研究ES6时,对ES6的特性、重点和注意事项的提取、精练和总结,可以做为ES6特性的字典;在本...
    科研者阅读 3,030评论 2 9
  • 引用:http://hao.jser.com/archive/10813/?utm_source=tuicool&...
    庄志平阅读 1,179评论 1 14
  • ES6带来了Javascript新的变化,新的语法特性,使得之以前版本中需要特性方式才能解决的问题一些问题得到了简...
    Patrick浩阅读 635评论 0 1
  • 概念: 1.ECMAScript 6(以下简称ES6)是JavaScript语言的下一代标准。          ...
    Sujz阅读 215评论 1 2