下载安卓APP箭头
箭头给我发消息

客服QQ:3315713922

web前端:ES6 Map

作者:张最棒     来源: https://www.cnblogs.com/jiaobaba/p/11899620.html点击数:707发布时间: 2020-03-13 15:19:33

标签: 数据结构ES6构造函数

Web开发

  构造函数,是一种特殊的方法。主要用来在创建对象时初始化对象,即为对象成员变量赋初始值,总与new运算符一起使用在创建对象的语句中。特别的一个类可以有多个构造函数,可根据其参数个数的不同或参数类型的不同来区分它们即构造函数的重载。

  Map是ES6提供给我们的构造函数,本质上是键值对的集合。他和对象类似

  特点:key对应value,key和value唯一,任何值都可以当属性(包括对象)。但在Javascript的Object属性和值构成的是”字符串-值“对,属性只能是字符串,如果传个对象字面量作为属性名,那么会默认把对象转换成字符串,结果这个属性名就变成”[objectObject]“。ES6提供了”值-值“对的数据结构,键名不仅可以是字符串,也可以是对象。它是一个更完善的Hash结构。

  创建Map

  1.创建一个空map

  letmap=newMap();

  2.创建map并初始化时map和set不同,map只接收数组作为参数,并且数组成员还是一个个数组,其中包含两个元素,一个代表键,一个代表值

  letmap=newMap([["name","zwq"],['age','18'],['sex',true],[{},'对象也可以是属性名']]);

  console.log(map);//Map(4){"name"=>"zwq","age"=>"18","sex"=>true,{…}=>"对象也可以作为属性名"}

  例如当你想把dom对象最为属性名时,在Object里作为属性名是会被toString的{[objectHTMLDivElement]:20},这是你就可以使用map会这样存下div.wrapper=>"20"}

  使用api添加值和取值

  map.set('name','zwq');

  map.set('age','20');

  console.log(map.get(wrapper));20

  console.log(map.get({}));//undedinde因为当前的对象不是之前的那个对象了,你需要把对象用变量存一下。

  delete()删除键值对。

  clear()清空map

  size()返回map的长度

  keys()返回所有的属性名

  has('属性名')看map里面有没有属性返回true,false

  遍历map

  方法一

  map.forEach(function(ele,key,self){

  console.log(ele,key,self);//true"sex"Map(1){"sex"=>true}

  })

  方法二

  for(varpropofmap){

  console.log(prop);//返回把键值对变成数组["name","zwq"]["age","20"]

  console.log(prop[0],prop[1]);拿到属性名,属性值

  }

  构造函数的功能主要用于在类的对象创建时定义初始化的状态。它没有返回值,也不能用void来修饰。这就保证了它不仅什么也不用自动返回,而且根本不能有任何选择。

赞(9)
踩(0)
分享到:
华为认证网络工程师 HCIE直播课视频教程