Es6中特性的相关概念

一,解构赋值

概念:ES6中允许从数组中提取值,按照对应位置,对变量赋值,对象也可以实现解构

1.数组解构:

数组解构允许我们按照一一对应的关系从数组中提取值,然后将值赋值给变量

 let [a, b, c] = [1, 2, 3];
 console.log(a)//1
 console.log(b)//2
 console.log(c)//3
 //如果解构不成功,变量跟数值个数不匹配的 时候,变量的值为undefined

2.对象解构:

对象解构允许我们使用变量的名字匹配对象的属性,匹配成功将对象属性的值赋值给变量

还可以解构赋值重命名({name: myName})

 let person = { name: 'zhangsan', age: 20 }; 
 let { name, age } = person;
 console.log(name); // 'zhangsan' 
 console.log(age); // 20

 // name 是属性   myName 是变量 解构赋值重命名
 let {name: myName, age: myAge} = person; // myName myAge 属于别名
 console.log(myName); // 'zhangsan' 
 console.log(myAge); // 20

总结:

解构赋值就是把数据结构分解,然后给变量进行赋值

如果结构不成功,变量跟数值个数不匹配的时候,变量的值为undefined

数组解构用中括号包裹,多个变量用逗号隔开,对象解构用花括号包裹,多个变量用逗号隔开

利用解构赋值能够让我们方便的去取对象中的属性跟方法

二,剩余参数

(当实参个数大于形参个数时,可以将剩余的实参放入一个数组中 )

概念:剩余参数语法允许我们将一个不定数量的参数表示为一个数组,不定参数定义方式,这种方式很方便的去声明不知道参数情况下的一个函数

//...args 代表剩余的实参以数组的形式都接收了
function sum (first, ...args) {
     console.log(first); // 10
     console.log(args); // [20, 30] 
 }
 sum(10, 20, 30) 

// 第二种写法
const sum = (...args) => {
			let total = 0;
			args.forEach(item => total += item);
			return total;
		};

		console.log(sum(10, 20));
		console.log(sum(10, 20, 30));

剩余参数和解构配合使用:

let students = ['wangwu', 'zhangsan', 'lisi'];
let [s1, ...s2] = students; 
console.log(s1);  // 'wangwu' 
console.log(s2);  // ['zhangsan', 'lisi']

三,扩展运算符

概念:扩展运算符可以将数组或者对象转为用逗号分隔的参数序列

 let ary = [1, 2, 3];
 ...ary  // 1, 2, 3
 console.log(...ary);    // 1 2 3,相当于下面的代码
 console.log(1,2,3);

 扩展运算符可以应用于合并数组

 // 方法一 
 let ary1 = [1, 2, 3];
 let ary2 = [3, 4, 5];
 let ary3 = [...ary1, ...ary2];
 // 方法二 
 ary1.push(...ary2);

将伪数组或可遍历对象转换为真正的数组

let oDivs = document.getElementsByTagName('div')
oDivs = [...oDivs]

 四,构造函数方法:Array.from()

将伪数组或可遍历对象转换为真正的数组

//定义一个集合
let arrayLike = {
    '0': 'a',
    '1': 'b', 
    '2': 'c',
    length: 3
}; 
//转成数组
let arr2 = Array.from(arrayLike); // ['a', 'b', 'c']

Array.from()方法还可以接受第二个参数,作用类似于数组的map方法,用来对每个元素进行处理,将处理后的值放入返回的数组

 let arrayLike = { 
     "0": 1,
     "1": 2,
     "length": 2
 }
 // Array.from() 第一个参数:要转换的元素 第二个参数是一个函数
 let newAry = Array.from(arrayLike, item => item *2)//[2,4]

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值