JavaScript一种新的数据结构类型Map
什么是map
它类似于对象,是键值对的集合,但键的范围不局限在于字符串。各种类型的值(包含对象)都可以作为键。
如果同一个键被多次赋值,后面的值将会覆盖其那面的值。如果读取一个未知的键,返回的是undefined.
具有极快的查找速度,它的查找的方式比遍历的方式更加的块。
创建map的时候需要:1.初始化Map需要一个二维数组 2.或者直接初始化一个空Map。
通过map可以快速获取某个键的值【场景使用】
它的常见方法 set()添加 get()获取值 delete()删除值 has()判断是否有某个值 clear()方法清除所有成员,没有返回值。
场景描述 [项目中可以使用]
如果我们我们想要获取某个人的成绩, 必须要通过遍历的方式去获取成绩。
并且Array越长,耗时越长。
但是如果使用map就不需要了。只需要一个“名字”-“成绩”的对照表,
let arr = [{
name: '张三',
grade: 100
}, {
name: '李四',
grade: 100
}, {
name: '王五',
grade: 100
}]
//这个是map
var m = new Map([
['张三', 100],
['李四', 97],
['王五', 85]
]);
let chengjizs = m.get('张三');
console.log('成绩是', chengjizs)
如何快速获取后端返回来的某值
//假设后端返回来了很多数据,我们需要获取某一个值。
//可以先将数据转为map类型的数据结构 [[key:value]] 一个二维数组
//然后通过 数据源.get(key) 的方式获取值
let backArr = [{
name: '张三',
grade: 100
}, {
name: '李四',
grade: 100
}, {
name: '王五',
grade: 100
}]
let newArr = []
backArr.forEach(item => {
newArr.push([item.name, item.grade])
})
// Map的参数格式是[[key:value],[key:value]]这样才可以通过get方法来获取对应的value
let arrMap = new Map(newArr)
console.log(arrMap.get('张三'))
创建Map以及Map的常见方法
// 初始化Map需要一个二维数组, 或者直接初始化一个空Map。
var m = new Map(); // 这个是一个空Map
console.log(m.set('Aa', 67)); // 添加新的key-value
console.log(m.has('Aa')); // 是否存在key 'Aa'输出的值是:true
console.log(m.get('Aa')); // 获取Aa的67
console.log(m.delete('Aa')); // 删除key 'Aa'
console.log(m.get('Adam')); // 读取未知的值 undefined
console.log(m.clear()); //清除所有值
set()添加 get()获取值 delete()删除值 has()判断是否有某个值
获取map对象中所有的key值,并且把它转为为一个数组
var m = new Map([
['张三', 100],
['李四', 97],
['王五', 85]
]);
let keysName = m.keys(); //返回的所有key值,但却不是一个数组
console.log(Array.from(keysName)) //转为为一个数组
Map 结构原生提供三个遍历器生成函数和一个遍历方法。
Map.prototype.keys():返回map的所有键名。
Map.prototype.values():返回map的所有键值。
Map.prototype.entries():返回map的所有成员。
Map.prototype.forEach():遍历Map的所有成员。
Map 结构转为数组结构,比较快速的方法是使用扩展运算符(...)
const map = new Map([
[1, 'one'],
[2, 'two'],
[3, 'three'],
]);
let keyArr = [...map.keys()]
console.log(keyArr) //[1, 2, 3]
let contArr = [...map.values()]
console.log(contArr) //['one', 'two', 'three']
let arr1 = [...map.entries()]
console.log(arr1)
// [[1,'one'], [2, 'two'], [3, 'three']]
let arr2 = [...map]
console.log(arr2)
// [[1,'one'], [2, 'two'], [3, 'three']]
Map 转为对象
如果所有 Map 的键都是字符串,它可以无损地转为对象。
function strMapToObj(strMap) {
let obj = Object.create(null);
for (let [k, v] of strMap) {
obj[k] = v;
}
return obj;
}
const myMap = new Map([
['grade1', 100],
['grade2', 97],
['grade3', 85]
])
console.log(strMapToObj(myMap))
对象转为 Map 可以通过Object.entries()
let obj = {
"age": 12,
"name": '张三'
};
let map = new Map(Object.entries(obj));
console.log('map', map)
或者 我们自己写一个方法
function objToStrMap(obj) {
let strMap = new Map();
for (let k of Object.keys(obj)) {
strMap.set(k, obj[k]);
}
return strMap;
}
let newMap=objToStrMap({
yes: true,
no: false
})
console.log(newMap)
通过forEach循环map中的每一个值,以及key值
var m = new Map([
['张三', 100],
['李四', 97],
['王五', 85]
]);
m.forEach(function(value,index) {
console.log("value", value,index); //100 张三 这种
})
map.values() 遍历map的values
let map = new Map([
[1, '张三'],
[2, "李四"],
[3, "王五"]
])
let values = map.values();
for (i = 0; i < map.size; i++) {
value = values.next().value;
console.log(value); // 张三 李四 王五
}
JavaScript一种新的数据结构类型Map的更多相关文章
- javascript一种新的对象创建方式-Object.create()
1.Object.create() 是什么? Object.create(proto [, propertiesObject ]) 是E5中提出的一种新的对象创建方式,第一个参数是要继承的原型,如果不 ...
- ES6 一种新的数据结构--Map跟Objct的区别
var map1=new Map(); var keys={key:'val'}; map1.set(keys,'content'); ==> {Object {key: "val&q ...
- Source Insight添加新的文件类型
1.前言 Source Insight这个软件工具功能非常强大,很适合用来分析一些大型的code工程,例如Linux内核源码,本文将简单介绍如何在Source Insight工程中添加一种新的文件类型 ...
- javascript四种类型识别的方法
× 目录 [1]typeof [2]instanceof [3]constructor[4]toString 前面的话 javascript有复杂的类型系统,类型识别则是基本的功能.javascrip ...
- python定义一种新类型的元组
# 定义一种新类型的元组,只保留int类型,切只大于0的元素 # 例如:IntTuple([1,-1,"abc",6,['x','y'],3])==>(1,6,3) # 解决 ...
- 四种常见的数据结构、LinkedList、Set集合、Collection、Map总结
四种常见的数据结构: 1.堆栈结构: 先进后出的特点.(就像弹夹一样,先进去的在后进去的低下.) 2.队列结构: 先进先出的特点.(就像安检一样,先进去的先出来 ...
- ES6 之 Set数据结构和Map数据结构 Iterator和for...of循环
ECMAScript 6 入门 Set数据结构 基本用法 ES6提供了新的数据结构Set.它类似于数组,但是成员的值都是唯一的,没有重复的值. Set本身是一个构造函数,用来生成Set数据结构. va ...
- Java核心数据结构(List,Map,Set)原理与使用技巧
JDK提供了一组主要的数据结构实现,如List.Map.Set等常用数据结构.这些数据都继承自 java.util.Collection 接口,并位于 java.util 包内. 1.List接口 最 ...
- Java同步数据结构之Map概述及ConcurrentSkipListMap原理
引言 前面介绍了CopyOnWriteArraySet,本来接着是打算介绍ConcurrentSkipListSet,无耐ConcurrentSkipListSet的内部实现其实是依赖一个Concur ...
- ES6之新的数据结构
Set Set 类似于数组,是一种集合的数据结构,和 Array 之间最大的区别是: Set中所有的成员都是唯一的. 可以把Set想象成是一个: 既没有重复元素,也没有顺序概念的数组. Set 本身是 ...
随机推荐
- 解读知识蒸馏模型TinyBert
摘要:本篇文章的重点在于改进信息瓶颈的优化机制,并且围绕着高纬空间中互信息难以估计,以及信息瓶颈优化机制中的权衡难题这两个点进行讲解. 本文分享自华为云社区<[云驻共创]美文赏析:大佬对变分蒸馏 ...
- 顶级加密混淆混淆工具测评:ipagurd
顶级加密混淆混淆工具测评:ipagurd 摘要 JavaScript代码安全需求日益增长,因此JavaScript混淆工具的使用变得广泛.本文将对专业.商业JavaScript混淆工具ipagur ...
- 总结vue3 的一些知识点:Vue.js 条件语句
Vue.js 条件语句 条件判断 v-if 条件判断使用 v-if 指令: v-if 指令 在元素 和 template 中使用 v-if 指令: <div id="app" ...
- 玩转Python:处理图像,两个非常重要的库,很实用,附代码
在Python中,图像处理是一个涉及图像分析.编辑和处理的广泛领域.有几个流行的库通常用于处理图像,每个库都有其特殊的功能和优势.以下是一些常用的Python图像处理库: 1. Pillow (PIL ...
- StringBuilder 线程不安全,到底哪里不安全?
StringBuilder 线程不安全,到底哪里不安全? 在Java中,字符串拼接是一个非常常见的操作,而对于频繁变动的字符串内容,使用StringBuilder是一个性能优化的选择.但是,Strin ...
- <vue 路由 8、keep-alive的使用>
一. 知识点 1.什么是keep-alive? keep-alive是Vue.js的一个内置组件. 包裹动态组件时,会缓存不活动的组件实例,而不是销毁它们.它自身不会渲染一个 DOM 元素,也 ...
- 【驱动】SPI驱动分析(三)-SPI关键数据类型
SPI数据类型 SPI控制器驱动结构体 struct spi_master抽象了控制器硬件,在SoC中的指的就是内部SPI控制器,当向SPI核心层注册一个SPI控制器时就需要提供这样的一个结构体变量. ...
- vue实现word或pdf文档导出的功能
https://www.jianshu.com/p/73915ef6ac89 Vue - element-ui 中预览 word .exce.ppt以及pdf文件 https://blog.csdn. ...
- freeswitch号码变化方案
概述 freeswitch是一款简单易用的开源音视频软交换平台. 在生产环境中,由于各个线路的号码规则并不统一,经常需要针对中继线路做号码变换的方案. 本文主要介绍fs中有哪些可选的号码变换方案. 环 ...
- off-policy RL | Advantage-Weighted Regression (AWR):组合先前策略得到新 base policy
论文题目:Advantage-Weighted Regression: Simple and Scalable Off-Policy Reinforcement Learning,ICLR 2020 ...