es6新增特性总结

本文详细介绍了ES6引入的关键字如let和const,以及新特性如解构赋值、箭头函数、模板字符串等。重点讲解了数组方法如of(),from(),find(),fill(),copyWithin()等,并介绍了Map和Set数据结构,对象的assign和is方法,以及模块导入的新机制。
摘要由CSDN通过智能技术生成

es6新增特性
1.let和const关键字
2.解构赋值
3.箭头函数
4.模板字符串:使用反引号``代替双引号创建字符串
5.标签模板
6.扩展运算符
7.新增了一些字符串和数组方法
 

数组方法::

01:of()是ES6新增的用于创建数组的方法。

of把传入的参数当做数组元素,形成新的数组。

let arr = Array.of(1,'2',[3],{}); console.log(arr); //[1,'2',[3],{}]

02:from()方法:可以将可迭代对象转换为新的数组。函数可接受3个参数:第一个表示将被转换的可迭代对象,第二个是回调函数,将对每个数组元素应用该回调函数,然后返回新的值到新数组,第三个是回到函数内this的指向。后两个参数是可选的。

let obj = { double(n) { return n * 2; } } let arr = [1, 2, 3]; console.log(Array.from(arr, function (n){ return this.double(n); }, obj)); // [2, 4, 6]

03:find()和findIndex(),查找数组中符合条件的元素值或索引,方法不会修改原数组。

let arr = [1,2,3,4,5]; console.log(arr.find((ele) => { return ele === 1; }));//1 console.log(arr.findIndex((ele) => { return ele > 4; })); //4

04:fill()/copyWithin(),替换数组中部分元素,会修改原数组。

let arr = [1,2,3,4,5]; console.log(arr.fill(0,0,3));//[0,0,0,4,5] //参数1表示目标值,参数2,3表示替换的始末位置,左闭右开区间。 console.log(arr.copyWithin(0,2,4));//[0,4,0,4,5] //参数1表示修改的起始位置,参数2,3表示用来替换的数据的始末位置,左闭右开区间。

05: includes()用于检测数组是否包含某个值,可以指定开始位置。

8.Symbol
9.迭代器(Iterator)
10.生成器
11.Promise承诺

12.Map和Set

  Map对象用于保存键值对,任何值JavaScript支持的值都可以作为一个键或者一个值。这听起来和对象差不多啊?其实它们还是有区别的:

    a) object的键只能是字符串或ES6的symbol值,而Map可以是任何值。

    b) Map对象有一个size属性,存储了键值对的个数,而object对象没有类似属性。

13.

ES6对象新增了两个方法,assign和is。

  assign用于浅拷贝源对象可枚举属性到目标对象。

e = {a:{ b: 1},b: 2}; let target = {c: 3}; Object.assign(target, source); console.log(target); //{c: 3, a: {b:1}, b: 2} source.a.b = 2; console.log(target.a.b); //2 

  如果有同名属性,那么目标对象的属性值会被源对象的属性值覆盖。所以数组的表现就有一点特别了:

  数组的index就是属性名,当使用assign方法时,从第0位开始,目标数组的值便开始被源数组的值覆盖了。

  is方法和(===)功能基本类似,用于判断两个值是否绝对相等。

Object.is(1,1);//true Object.is(1,true);//false Object.is([],[]);//false Object.is(+0,-0);//false Object.is(NaN,NaN);//true

  他们仅有的两点区别是,is方法可以区分+0还是-0,还有就是它认为NaN是相等的

14:导入

  ES6使用关键字 import 导入模块(文件),有两种常用的方式:

import ‘模块名称’ from ‘路径’;

import ‘路径’;

  • 24
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
回答: ES6中的Set和Map是两种新增的集合类型。Set是一种无重复值的集合,可以通过new Set()来创建。它具有add方法用于向集合中添加元素,has方法用于判断集合中是否存在某个元素,clear方法用于清空集合。Set也可以用于数组去重,通过new Set(\[...\])的方式将数组转换为Set,利用Set的特性去除重复值。\[1\] Map是一种键值对的集合,可以通过new Map()来创建。它具有set方法用于向集合中添加键值对,get方法用于获取指定键名对应的值,has方法用于判断集合中是否存在某个键名,clear方法用于清空集合。Map的键名可以是任意数据类型,包括引用值,但需要注意的是,引用值作为键名时,需要使用相同的引用地址才能获取到对应的值。\[2\] Set和Map都可以使用for...of循环或forEach方法进行遍历。在Set中,forEach的第二个参数是集合的元素,因为Set中不存在下标。而在Map中,forEach的第一个参数是键值对的值,第二个参数是键值对的键名。\[3\] 总结来说,Set和Map是ES6新增的集合类型,Set用于存储无重复值的集合,Map用于存储键值对的集合。它们提供了一些方法来操作集合,如添加、获取、判断是否存在等。在使用时需要注意它们的特性和方法的使用方式。 #### 引用[.reference_title] - *1* *2* [ES6中的Map和Set详解](https://blog.csdn.net/m0_45093055/article/details/126430467)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [ES6中的set与map](https://blog.csdn.net/weixin_44247866/article/details/127561391)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^insert_down1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值