ES6系列之解构
本系列是在平时阅读、学习、实际项目中有关于es6中的新特性、用发的简单总结,目的是记录以备日后温习;本系列预计包含let/const、箭头函数、解构、常用新增方法、Symbol、Set&Map、Proxy、reflect、Class、Module、Iterator、Promise、Generator、async/await。。。
解构个人理解就是相同模式,可以对应赋值,属于“模式匹配”
基本用法
// 基本用法
let [a, b] = [1, 2]; // x = 1, y = 2
let [, c] = [3, 4]; // c = 4
let [d, e] = [1]; // d = 1, e = undefined // 与...结合使用
let [f, ...tail] = [1, 2, 3, 4]; // e = 1, tail = [2, 3, 4] // 等号右侧为非可遍历对象,则抛出异常
let [g, h] = null; // Uncaught TypeError: null is not iterable
// 设定默认值
let [i = 'i'] = []; // i = 'i'
对象解构
// 基本用法
let {a, b} = {a: 'aa', b: 'bb'}; // a = 'aa', b = 'bb' // 如果变量名和属性名不一致
let {foo: bar} = {foo: 1, baz: 2}; // bar = 1 (注意:这里foo这个变量仍然没有被定义,如果试图访问变量foo,则会抛出异常: Uncaught ReferenceError: foo is not defined) // 上面的异常情况其实是证明对象的解构其实是下面这种写法的简写,也就是说: 对象的解构赋值的内部机制,是先找到同名属性,然后再赋给对应的变量
let {a: _$, b: $_} = {a: 1, b: 2}; // _$ = 1, $_ = 2 // 指定默认值
let {c, d = 'dd'} = {c: 'cc'} // c = 'cc', d = 'dd' // 下面这种情况会抛出错误
let x;
{x} = {x: 'xx'}; // Uncaught SyntaxError: Unexpected token =
// 因为上面的情况开头的{会被解析为代码块,应该改成这样
({x} = {x: 'xx'});
字符串解构
const [a, b, c, d, e] = 'hello';
a // "h"
b // "e"
c // "l"
d // "l"
e // "o"
数值、布尔值解构
let {toString: s} = 123;
s === Number.prototype.toString // true let {toString: s} = true;
s === Boolean.prototype.toString // true // 对于数值和布尔值的解构,会先将其转化为包装对象,然后进行模式匹配、赋值
函数参数的解构
function add([x, y]){
return x + y;
} add([1, 2]); // // 指定默认值
function move({x = 0, y = 0} = {}) {
return [x, y];
} move({x: 3, y: 8}); // [3, 8]
move({x: 3}); // [3, 0]
move({}); // [0, 0]
move(); // [0, 0] function move1({x, y} = { x: 0, y: 0 }) {
return [x, y];
} move1({x: 3, y: 8}); // [3, 8]
move1({x: 3}); // [3, undefined]
move1({}); // [undefined, undefined]
move1(); // [0, 0] // 上面函数move和move1默认值的区别是: move的参数是一个对象,并为参数对象的属性指定默认值;move1的参数是一个对象,并为参数指定默认值,该默认值是{x: 0, y: 0}
用途
(1)交换变量值
let x = 1;
let y = 2; [x, y] = [y, x];
(2)函数返回多个值
function example() {
return [1, 2, 3];
}
let [a, b, c] = example();
(3)函数参数定义
// 参数是一组有次序的值
function f([x, y, z]) { ... }
f([1, 2, 3]); // 参数是一组无次序的值
function f({x, y, z}) { ... }
f({z: 3, y: 2, x: 1});
(4)提取JSON数据
let jsonData = {
id: 42,
status: "OK",
data: [867, 5309]
}; let { id, status, data: number } = jsonData;
(5)为函数参数指定默认值(这个之前的例子已经有所体现)
ES6系列之解构的更多相关文章
- [js高手之路]es6系列教程 - 解构详解
解构通俗点说,就是通过一种特定格式,快捷的读取对象/数组中的数据的方法, es6之前,我们通过对象名称[键] 读取数据 var User = { 'name' : 'ghostwu', 'age' : ...
- es6学习笔记--解构赋值
昨天学习了es6语法中解构赋值,解构赋值在声明中和函数传参提高了灵活性和便捷性,值得掌握该语法. 概念: ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值,这被称为解构. 数组的解构 ...
- 关于ES6 的对象解构赋值
之 前写了关于ES6数组的解构 现在 go on ; 解构不仅可以用于数组,还可以用于对象: 对象的解构和数组有一个重要的不同.数组的元素是按次序排列的,变量的取值是由他的位置决定的:而对象的属性没有 ...
- 【JS】325- 深度理解ES6中的解构赋值
点击上方"前端自习课"关注,学习起来~ 对象和数组时 Javascript 中最常用的两种数据结构,由于 JSON 数据格式的普及,二者已经成为 Javascript 语言中特别重 ...
- ES6 - Note2:解构赋值
ES6的解构赋值就是利用模式匹配从按照一定模式的数组或者对象中提取值赋值给变量. 1.数组的解构赋值 在ES6以前,变量的赋值是直接指定的,以后可以这么来写,如下所示 let [a,b,c] = [1 ...
- ES6 变量的解构赋值
数组的解构赋值 var [a,b,c] = [1,2,3]; 左边是变量,右边是值,根据数据结构一一对应 只要等号两边的模式相同,左边的变量就会被赋予右边对应的值,必须模式相同 如果等号 ...
- ES6新特性-------解构、参数、模块和记号(续)
六.解构 解构提供了一个方便的地从对象或数组中提取数据的方法,请看下面的例子: //ES6 let [x,y]=[1,2];//x=1,y=2 //ES5 var arr=[1,2]; var x=a ...
- ES6 - 变量的解构赋值学习笔记
变量的解析赋值 数组的解析赋值 es6允许按照一定的模式,从数组和对象中提取值,对变量进行赋值,这就称为解构. var a = 1; var b = 2; var c = 3; //在es6中允许写成 ...
- ES6的变量解构赋值
前 言 ES6 解构赋值: ES6允许按照一定模式从数组和对象中提取值,然后对变量进行赋值,这被称为解构. 1.1 数组的结构赋值 1.1.1基本用法 JS中,为变量赋值直接指定.例如下面代码: ...
随机推荐
- Go Lang
IDE: https://www.jetbrains.com/products.html?fromMenu#type=ide Study: http://www.runoob.com/go/go-en ...
- C#中的Cookie
cookie属性: name字段为一个cookie的名称. value字段为一个cookie的值. domain字段为可以访问此cookie的域名. path字段为可以访问此cookie的页面路径. ...
- reducer 按key聚合
#coding=utf8 import sys import itertools import json reload(sys) sys.setdefaultencoding("utf8&q ...
- flask-不错的教程
https://spacewander.github.io/explore-flask-zh/7-blueprints.html
- SQLI DUMB SERIES-20
(1)登录成功后页面: (2)登录成功后,用burp开始抓包,刷新浏览器页面,将会跳出如下页面 (3)根据各种提示,知道需要从cookies入手,寻找闭合方式 闭合方式为单引号.注释符也可以用 (4) ...
- Day1-浅谈接口测试
1.接口测试的定义:从数据库里面取数据,插入数据,把前段和后端联系起来: 2.接口测试的必要性: 1)前端未开发好,但是接口已开发 2)页面上测不了的,可以通过接口来测试 3.接口测试需要注意: 1) ...
- vue项目localhost可以访问 ip不能访问
解决方法: 如图所示:
- Elasticsearch2.3.4使用手册(使用存储过程做增量同步的探索)
一.工具安装 访问官网https://www.elastic.co/downloads/elasticsearch和http://xbib.org/repository/org/xbib/elasti ...
- vue day4 table
<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content ...
- 如何让input框显示在一行?
案例: <input type="float:left" value="aaaa"> <input type="float:left ...