新的数据结构

  • Set
  • Map

Set

Set是一个构造函数
必须使用new调用
用于实例化一个set对象
set对象用来存储任意类型的唯一值
<new Set()
new Set(iterable)

  • iterable
    可迭代对象

返回值:返回一个新创建的Set对象。
示例:创建一个空Set

new Set()

示例:创建一个Set对象

   const arr = [1,2,3,4,3,2,1]
        let set = new Set(arr)
        console.log(set);//Set(4) [ 1, 2, 3, 4 ]

示例:创建一个Set对象

const obj ={y:1}
const arr = [1,obj,{x:1},obj,{x:1}]
let set = new Set(arr)
console.log(set);
size: 4
<entries>
0: 1
1: Object { y: 1 }
2: Object { x: 1 }
3: Object { x: 1 }

1.Set.prototype.add()

用于向Set对象中添加新值。如果值存在则不添加
语法:

set.add(value)//任意类型的值

返回值:更新后的对象
用法:

  const obj ={y:1}
        const arr = [1,obj,{x:1},obj,{x:1}]
        let set = new Set(arr)
        set.add("小猫")
        set.add(NaN)
        set.add(NaN).add(NaN)
        console.log(set);//Set(6) [ 1, {…}, {…}, {…}, "小猫", NaN ]

Set.prototype.has()

拥有检索Set对象是否存在指定值
语法:

set.hase(value)//任意值

返回值:
true:存在
false:不存在

Set.prototype.delete()

  • delete() 方法从 Set 对象中删除指定的值(如果该值在 Set 中)。
    语法:
delete(value)

返回值:true删除成功 false不成功

Set.forEach

遍历set
语法:

set.forEach(value,key,set){
}

value:值
key:索引,key没有键,使用value值也会给key
set:set对象名

修改set对象中的值

let set = new Set
set.forEach((value,key,set)=>{
// console.log(value);
// console.log(key);
// console.log(set);
if(value===1)value= "ccc"
console.log(value);
})

Map()

定义:

  • Map()是ES6新增的内置构造函数
  • Map()构造函数用于创建Map对象。(也被称为词典)
  • 传入一个数组会报错
  • 必须传入一个键值对形式的对象

语法:

new  map()

返回值:一个map对象,键值对具有唯一性
示例:

 const map =new Map()
        console.log(map);

示例:

  let obj = [["x","y"],["1","2"],["x","y"]]
        const map =new Map(obj)
        console.log(map);//Map { x → "y", 1 → "2" }

Map对象是什么

  • Mam对象引入的一种新型数据结构
  • 和JS中Object一样,也使用键值对形成存储数据
  • 和Object不一样的地方
    有序存储,Map会记录存储位置
    Map对象中的key可以是任意数据类型,obj的key只能是字符串,symbol,计算属性
    map有长度,Object没有;
    map可迭代,obj不可以迭代
    对象是键值的无序集合,map是键值的有序集合
  • map是键值对的有序集合

语法:

new Map()
new Map(iterable)

iterable:必须是键值对和可迭代对象

map增删改查

1.增

Map.prototype.set()
  • set() 方法为 Map 对象添加或修改一个键(key)和值(value)的(新)键值对。
    语法:
map.set(key, value)

返回值:返回更新后的map对象
示例,添加一个新的键值对:

  let a = 1+1
    function fn(){}
    let obj = [[0,"a"],[a,"b"],[1,"c"],[fn(),"d"],[undefined,"e"],[NaN,"e"],["c","g"]]
    const map =new Map(obj)
    map.set("黄油符","投影仪")
    console.log(map);//Map(7) { 0 → "a", 2 → "b", 1 → "c", undefined → "e", NaN → "e", c → "g", "黄油符" → "投影仪" }

示例,修改键值对:

  let a = 1+1
    function fn(){}
    let obj = [[0,"a"],[a,"b"],[1,"c"],[fn(),"d"],[undefined,"e"],[NaN,"e"],["c","g"]]
    const map =new Map(obj)
    map.set("黄油符","投影仪")
    console.log(map);//Map(7) { 0 → "a", 2 → "b", 1 → "c", undefined → "e", NaN → "e", c → "g", "黄油符" → "投影仪" }
 map.set("黄油符","记录委员")
    console.log(map.get("黄油符"));//记录委员

2.删

Map.prototype.clear()
  • clear() 方法会移除 Map 对象中的所有键值对。

语法:

map.clear()

无参数
返回undefined

Map.prototype.delete()
  • delete() 方法用于移除 Map 对象中指定的键值对。
    语法:
map.dalete(key)

返回值:true删除成功 false不成功

3.改

Map.prototype.set()
  • set() 方法为 Map 对象添加或修改一个键(key)和值(value)的(新)键值对。
    语法:
map.set(key, value)

返回值:返回更新后的map对象

4.查

Map.prototype.has()
  • has() 方法返回一个布尔值,查询指定键的元素是否存在。

返回值:true存在 false不存在

Map.prototype.get()

定义:get()方法用于查询指定key的value
语法:

map.get(key)

返回值:value查到了
undefied:没有找到
示例:

    let obj = [[null,"y"],[["a"+"b"],"2"],[1,"y"],[function(){},true],[undefined,"c"],[NaN,1]]
        const map =new Map(obj)
        console.log(map.get(null));//y

map.prototype.forEach()

用于遍历map对象
语法:

forEach(callbackFn)
forEach(callbackFn, thisArg)

返回undefined
示例:

        const bod1 = {name:"cyh"}
        const girl2 = {name:"wl"}
        const bod2 = {name:"tl"}
        const map = new Map([
            [bod1,"记录"],
            [girl2,'蒙城'],
            [bod2,"插座"]
        ])
        map.forEach((value,key,map)=>{
            console.log(value);//记录 蒙城  插座
            console.log(key);//Object { name: "cyh" }
        })

map.keys

定义:keys() 返回一个引用迭代器,它包含按照顺序插入 Map 对象中每个元素的 key 值。

语法:

map.keys()

注意:单独提取键值对需要配合next().value
返回值:一个新的可迭代的 Map 迭代器对象。

示例1拿到keys:

 const bod1 = {name:"cyh"}
        const girl2 = {name:"wl"}
        const bod2 = {name:"tl"}
        const map = new Map([
            [bod1,"记录"],
            [girl2,'蒙城'],
            [bod2,"插座"]
        ])
        const maps = map.keys()
        console.log(maps.next().value);//Object { name: "cyh" }

Map.prototype.values()

返回一个可迭代map对象,包含按照顺序返回map的value值
语法:

map.values()

注意:单独提取键值对需要配合next().value
示例:

const bod1 = {name:"cyh"}
        const girl2 = {name:"wl"}
        const bod2 = {name:"tl"}
        const map = new Map([
            [bod1,"记录"],
            [girl2,'蒙城'],
            [bod2,"插座"]
        ])
        const values = map.values()
        console.log(values.next().value);//记录

map.prototype.entries()

返回一个新的迭代器map对象,其中包含 Map 对象中按插入顺序排列的每个元素的 [key, value] 对。
语法:

map.entries()

返回值:返回一个可迭代map对象
注意:单独提取键值对需要配合next().value
示例:

           const bod1 = {name:"cyh"}
        const girl2 = {name:"wl"}
        const bod2 = {name:"tl"}
        const map = new Map([
            [bod1,"记录"],
            [girl2,'蒙城'],
            [bod2,"插座"]
        ])
        const maps = map.entries()
        console.log(maps.next().value);//Array [ {name:cyh}}, "记录" ]

map.prototype.size

只读属性
返回map对象中有多少属性
语法:

map.size

返回值:数值,返回map对象中有多少属性
示例:

      const bod1 = {name:"cyh"}
        const girl2 = {name:"wl"}
        const bod2 = {name:"tl"}
        const map = new Map([
            [bod1,"记录"],
            [girl2,'蒙城'],
            [bod2,"插座"]
        ])
        console.log(map.size);//3

es6计算属性

es6命名对象key的方法。
用方括号设置对象的属性名
对象的属性名是一个表达式

const obj = {
[a+b]:x
}

对象的属性名必须是一个字符串或计算属性或symbol

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

推荐阅读更多精彩内容

  • ES6引入了2种新的数据结构 Set Map Set()是什么? 定义: Set()是一个构造函数。 必须使用ne...
    烂好人_5b0f阅读 192评论 0 1
  • 在ECMAScript中,定义了下面几种基本的数据结构,分为值类型和引用类型:值类型数据结构: String - ...
    珍珠林阅读 211评论 0 0
  • 考题:一、Set对象是什么?1.Set对象是一种新型的数据结构;2.Set对象是一种存储任何类型的唯一值的,新型的...
    忧油鱼阅读 156评论 0 1
  • Set 基本用法 ES6 提供了新的数据结构 Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。 Set...
    硅谷干货阅读 353评论 0 0
  • 1.Set ES6 提供了新的数据结构 Set。它类似于数组,但是成员的值都是唯一的,没有重复的值。 Set本身是...
    黑云阅读 358评论 0 2