读阮一峰《ECMAScript 6 入门》小结
读阮一峰《ECMAScript 6 入门》小结,http://es6.ruanyifeng.com/
1. ES6简介
Babel 是一个广泛使用的 ES6 转码器,可以将 ES6 代码转为 ES5 代码
在线转换:https://babeljs.io/repl/
2. let和const命令
let
在块级作用域内有效,var
有变量提升(变量可以在声明之前使用,值为undefined
),声明的变量有内存泄露
const
定义常量,不能改变
如果区块中存在
let
和const
命令,这个区块对这些命令声明的变量,从一开始就形成了封闭作用域。凡是在声明之前就使用这些变量,就会报错都属于变量的“死区”。
3. 变量的解构赋值
- 数组的解构
let [a, b, c] = [1, 2, 3]; // a=1;b=2;c=3
let [a, ...b] = [1, 2, 3, 4]; // a=1;b=[2, 3, 4];
let [x, y = 'b'] = ['a', undefined]; // x='a', y='b'
let [x = 1] = [null]; // x=null注意,ES6 内部使用严格相等运算符(===),判断一个位置是否有值。所以,只有当一个数组成员严格等于undefined,默认值才会生效。
- 对象的解构
let { foo, bar } = { foo: "aaa", bar: "bbb" };
等价于
let { foo: foo, bar: bar } = { foo: "aaa", bar: "bbb" };
// foo="aaa" ; bar="bbb"
let { foo: baz } = { foo: 'aaa', bar: 'bbb' };// baz="aaa"对象的解构赋值的内部机制,是先找到同名属性,然后再赋给对应的变量。真正被赋值的是后者,而不是前者。
- 字符串的解构赋值
const [a, b, c, d, e] = 'hello'; //'h','e','l','l','e'
let {length : len} = 'hello'; // len=5 - 数值和布尔值的解构赋值
函数参数的解构赋值
function add([x, y]){
return x + y;
} add([1, 2]); // 3
用途:
- 交换变量的值
[x, y] = [y, x]
- 从函数返回多个值
函数参数的定义
// 参数是一组有次序的值
function f([x, y, z]) { ... }
f([1, 2, 3]); // 参数是一组无次序的值
function f({x, y, z}) { ... }
f({z: 3, y: 2, x: 1});提取 JSON 数据
let jsonData = {
id: 42,
status: "OK",
data: [867, 5309]
}; let { id, status, data: number } = jsonData; console.log(id, status, number);
// 42, "OK", [867, 5309]- 函数参数的默认值
- 遍历 Map 结构
- 输入模块的指定方法
4. 字符串的扩展
- 可以被
for...of
循环遍历 includes()
:返回布尔值,表示是否找到了参数字符串。
startsWith()
:返回布尔值,表示参数字符串是否在原字符串的头部。
endsWith()
:返回布尔值,表示参数字符串是否在原字符串的尾部
这三个方法都支持第二个参数,表示开始搜索的位置。repeat()
: 返回一个新字符串,表示将原字符串重复n次padStart()
用于头部补全,padEnd()
用于尾部补全。'3'.padStart(2, '0') //03
- 模板字符串
$('#result').append(`
There are <b>${basket.count}</b> items
in your basket, <em>${basket.onSale}</em>
are on sale!
`);所有的空格和缩进都会被保留在输出之中
模板字符串中嵌入变量,需要将变量名写在${}
之中。
5. 正则的扩展
RegExp
构造函数第一个参数是一个正则对象,那么可以使用第二个参数指定修饰符。而且,返回的正则表达式会忽略原有的正则表达式的修饰符,只使用新指定的修饰符。u
修饰符,含义为“Unicode 模式”y
修饰符,叫做“粘连”(sticky)修饰符。后一次匹配都从上一次匹配成功的下一个位置开始const REGEX = /a/gy;
'aaxa'.replace(REGEX, '-') // '--xa'单单一个y修饰符对match方法,只能返回第一个匹配,必须与g修饰符联用,才能返回所有匹配。
s
修饰符:dotAll 模式
使得.
可以匹配任意单个字符。/foo.bar/s.test('foo\nbar') // true
- 后行断言
”先行断言“指的是,x只有在y前面才匹配,必须写成/x(?=y)/
。
”先行否定断言“指的是,x只有不在y前面才匹配,必须写成/x(?!y)/
。
“后行断言”正好与“先行断言”相反,x只有在y后面才匹配,必须写成/(?<=y)x/
”后行否定断言“则与”先行否定断言“相反,x只有不在y后面才匹配,必须写成/(?<!y)x/
。 - 具名组匹配
const RE_DATE = /(?<year>\d{4})-(?<month>\d{2})-(?<day>\d{2})/;
const matchObj = RE_DATE.exec('1999-12-31');
const year = matchObj.groups.year; // 1999
const month = matchObj.groups.month; // 12
const day = matchObj.groups.day; // 31
6. 数值的扩展
Number.isFinite()
Number.isNaN()
Number.parseInt()
Number.parseFloat()
Number.isInteger()
//判断是否是整数
Math.trunc()
//方法用于去除一个数的小数部分,返回整数部分
Math.sign()
//用来判断一个数到底是正数、负数、还是零(+1,-1,0,-0,NaN)
指数运算符:**
2 ** 3 // 8
2 ** 3 ** 2 // 相当于 2 ** (3 ** 2)
7. 函数的扩展
- ES6 允许为函数的参数设置默认值,即直接写在参数定义的后面。
- 参数默认值不是传值的,而是每次都重新计算默认值表达式的值。也就是说,参数默认值是惰性求值的。
let x = 99;
function foo(p = x + 1) {
console.log(p);
}
foo() // 100
x = 100;
foo() // 101 - 函数的
length
属性,将返回没有指定默认值的参数个数
(function (a, b, c = 5) {}).length
// 2 - rest 参数
function add(...values) {
let sum = 0;
for (var val of values) {
sum += val;
}
return sum;
}
add(2, 5, 3) // 10
- 箭头函数
如果箭头函数不需要参数或需要多个参数,就使用一个圆括号代表参数部分。
箭头函数有几个使用注意点:
(1)函数体内的this对象,就是定义时所在的对象,而不是使用时所在的对象。
(2)不可以当作构造函数,也就是说,不可以使用new命令,否则会抛出一个错误。
(3)不可以使用arguments对象,该对象在函数体内不存在。如果要用,可以用 rest 参数代替。
(4)不可以使用yield命令,因此箭头函数不能用作 Generator 函数。
8. 数组的扩展
9. 对象的扩展
见《ES6数组、对象的扩展》
10. Symbol
- 一种新的原始数据类型
Symbol
,表示独一无二的值。 - 用于对象的属性名,就能保证不会出现同名的属性
在对象的内部,使用 Symbol 值定义属性时,Symbol 值必须放在方括号之中。 - 消除魔术字符串
- Symbol 作为属性名,该属性不会出现在
for...in
、for...of
循环中,也不会被Object.keys()
、Object.getOwnPropertyNames()
、JSON.stringify()
返回。但是,它也不是私有属性,有一个Object.getOwnPropertySymbols
方法,可以获取指定对象的所有 Symbol 属性名。
11. Set 和 Map 数据结构
Set 数据结构
它类似于数组,但是成员的值都是唯一的,没有重复的值。
Set 结构的实例有以下属性。
Set.prototype.constructor
:构造函数,默认就是Set
函数。Set.prototype.size
:返回Set
实例的成员总数。
Set 实例的方法分为两大类:操作方法(用于操作数据)和遍历方法(用于遍历成员)。下面先介绍四个操作方法。
add(value)
:添加某个值,返回 Set 结构本身。delete(value)
:删除某个值,返回一个布尔值,表示删除是否成功。has(value)
:返回一个布尔值,表示该值是否为Set
的成员。clear()
:清除所有成员,没有返回值。
Array.from
方法可以将 Set 结构转为数组。
去重:
const items = new Set([1, 2, 3, 4, 4]);
//方法一
[...items]
//方法二
Array.from(items);
// [1, 2, 3, 4]
Map 数据结构
它类似于对象,也是键值对的集合,但是“键”的范围不限于字符串,各种类型的值(包括对象)都可以当作键。
12. Proxy 代理器
Proxy 可以理解成,在目标对象之前架设一层“拦截”,外界对该对象的访问,都必须先通过这层拦截,因此提供了一种机制,可以对外界的访问进行过滤和改写。
get(目标对象,属性名,[proxy 实例本身])
用于拦截某个属性的读取操作set(目标对象,属性名,属性值,[proxy 实例本身])
用来拦截某个属性的赋值操作apply(目标对象,上下文对象(this),参数数组)
拦截函数的调用、call
和apply
操作。has
用来拦截HasProperty
操作,即判断对象是否具有某个属性时,这个方法会生效。典型的操作就是in
运算符。
has
拦截只对in
运算符生效,对for...in
循环不生效,导致不符合要求的属性没有被for...in
循环所排除。construct()
用于拦截new
命令deleteProperty()
用于拦截new
命令defineProperty()
拦截了Object.defineProperty
操作...
Reflect
Promise 对象
读阮一峰《ECMAScript 6 入门》小结的更多相关文章
- 读阮一峰老师 es6 入门笔记 —— 第一章
鉴于最近用 vuejs 框架开发项目,其中有很多涉及到 es6 语法不太理解所以便认真地读了一下这本书. 地址:http://es6.ruanyifeng.com/#README 第一章:let ,c ...
- 【js 笔记】读阮一峰老师 es6 入门笔记 —— 第一章
鉴于最近用 vuejs 框架开发项目,其中有很多涉及到 es6 语法不太理解所以便认真地读了一下这本书. 地址:http://es6.ruanyifeng.com/#README 第一章:let ...
- 【js 笔记】读阮一峰老师 es6 入门笔记 —— 第二章
第二章:变量的解构赋值 在es6 版本前,如果要为多个变量赋不同值,我想是件比较麻烦的事情.但es6 版本新推出了一个新技术那就是今天的主角变量的解构赋值. 变量解构赋值分为两种方法:数组解构赋值 和 ...
- 读阮一峰对《javascript语言精粹》的笔记,我有疑问。
<javascript语言精粹>是一本很棒的书籍,其中作者在附录列出了12种他所认为的javascript语言中的糟粕. 我最近开始跟读前端前辈的博客,其中读到了阮一峰的<12种不宜 ...
- react 入门教程 阮一峰老师真的是榜样
- 转自阮一峰老师博客 React 入门实例教程 作者: 阮一峰 日期: 2015年3月31日 现在最热门的前端框架,毫无疑问是 React . 上周,基于 React 的 React Nati ...
- 转: DNS 原理入门 (from 阮一峰)
转自:http://www.ruanyifeng.com/blog/2016/06/dns.html DNS 原理入门 作者: 阮一峰 日期: 2016年6月16日 DNS 是互联网核心协议之一. ...
- DNS 原理入门 - 阮一峰(转载)
DNS 原理入门 作者: 阮一峰 日期: 2016年6月16日 DNS 是互联网核心协议之一.不管是上网浏览,还是编程开发,都需要了解一点它的知识. 本文详细介绍DNS的原理,以及如何运用工具软件 ...
- react入门(1)之阮一峰react教程
阮一峰老师的github地址:React Demos React 入门实例教程 2.ReactDOM.render() // ReactDOM.render() 将模板转化为 HTML 语言 // 参 ...
- React 入门实例教程[阮一峰的网络日志] (分享)
作者: 阮一峰 https://github.com/ruanyf/react-demos 转自:http://www.ruanyifeng.com/blog/2015/03/react.html 对 ...
随机推荐
- 关于App程序猿泡沫
前言 做开发快七年了,对于程序猿,外行人总有着数不完的讽刺和误解,可是我都懒得去解释.代码搬运工人也好,民工也罢,随他们去说吧.可是网上近期流传的程序猿泡沫,尤其是APP程序猿泡沫的文章导致非常多我们 ...
- 推荐一款优雅的jquery手风琴特效
推荐一款基于 jQuery和 CSS3实现的手风琴效果. 查看demo演示
- Html+CSS基础之CSS样式
认识CSS样式 CSS全称为“层叠样式表 (Cascading Style Sheets)”,它主要是用于定义HTML内容在浏览器内的显示样式,如文字大小.颜色.字体加粗等. 如下列代码: p{ fo ...
- 日天的终生大事(dp)
日天的终生大事 题目描述 日天学长向妹子表白了,妹子说:“日天你那么聪明,回答我一个问题就答应你.你告诉我,L位K进制数有多少个?”日天表示这个问题太简单了,要求提高难度.妹子想了想说:“那么我增加一 ...
- scrollWidth到底是什么???
贴上MDN对scrollwidth的定义: The Element.scrollWidth read-only property is a measurement of the width of an ...
- 昼猫笔记 JavaScript -- 闭包
本次主要内容是 闭包 阅读时间: 约 3分钟 记得点个赞支持支持我哦 初步了解 先看下代码,输出结果是多少? function fn1 () { var a = 2 function fn2 () ...
- codeforces111D. Petya and Coloring(组合数学,计数问题)
传送门: 解题思路: 要求一条直线分割矩阵时左右颜色数一样,那么就说明一个问题.直线左右移动时是不会改变左右矩阵的颜色集合的.所以说明:2~m-1列的颜色集一定属于第一列与第m列颜色集的交集.而且第一 ...
- 模板实参推导 & xx_cast的实现
首先,类模板必须被显式特化.当然了,可以通过一个辅助函数,通过参数类型,返回特化的类模板,来间接处理. 这个技术被广泛应用在ptr_fun, make_pair, mem_fun, back_inse ...
- IOCP模型总结(总结回想)
IOCP旧代码重提.近期一直在玩其它方面的东东.时不时回想一下,收益多多. IOCP(I/O Completion Port,I/O完毕port)是性能最好的一种I/O模型.它是应用程序使用线程池处理 ...
- eXtremeDB相关问题解答(3)
> 1. Could our database support multi-database under one single instance? > > 2. ...