iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >js的Map函数怎么使用
  • 514
分享到

js的Map函数怎么使用

2023-06-29 01:06:01 514人浏览 八月长安
摘要

本文小编为大家详细介绍“js的Map函数怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“js的Map函数怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Map是ES2015引入的Global Obj

本文小编为大家详细介绍“js的Map函数怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“js的Map函数怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

Map是ES2015引入的Global Object,
Map对象中保存了键值对,且任何对象(包括原始值)都可以作为键或者值。

1. 构造函数

Map必须作为构造函数来使用,

new Map([iterable])

它的参数是可选的,如果提供的话,必须是一个iterable对象。
iterable对象的迭代结果为,[key1, value1], [key2, value2], ...

例如

// 1. 数组是一个iterable对象m = new Map([[1, 'a'], [2, 'b']]);    // Map(2) {1 => "a", 2 => "b"}// 2. generator会返回一个iterable对象gen = function*(){  yield [1, 'a'];  yield [2, 'b'];}iter = gen();m = new Map(iter);    // Map(2) {1 => "a", 2 => "b"}

2. 实例属性

m.size用来获取key的个数,

m = new Map([[1, 'a'], [2, 'b']]);    // Map(2) {1 => "a", 2 => "b"}m.size    // 2

3. 实例方法

(1)m.has(key),判断key是否存在
(2)m.get(key),取值,如果没有这个key就返回undefined(3)m.set(key, value),设值,返回m(4)m.delete(key),如果key存在且已经被删除了就返回true,如果key不存在就返回false。
(5)m.clear(),删除所有键值对

(6)m.keys(),返回一个iterable对象,其中包含了按插入顺序迭代的所有key

m = new Map([[1, 'a'], [2, 'b']]);    // Map(2) {1 => "a", 2 => "b"}[...m.keys()]    // [1, 2]

(7)m.values(),返回一个iterable对象,其中包含了按插入顺序迭代的所有value

m = new Map([[1, 'a'], [2, 'b']]);    // Map(2) {1 => "a", 2 => "b"}[...m.values()]    // ["a", "b"]

(8)m.entries(),返回一个iterable对象,每一个元素是[key, value],遍历顺序按key的插入顺序

m = new Map([[1, 'a'], [2, 'b']]);    // Map(2) {1 => "a", 2 => "b"}[...m.entries()]    // [[1, "a"], [2, "b"]]

注:更便捷的得到二维数组的方法是使用Array.from,它可以直接接受Map作为参数,

m = new Map([[1, 'a'], [2, 'b']]);    // Map(2) {1 => "a", 2 => "b"}Array.from(m)    // [[1, "a"], [2, "b"]]

Array.from也可以接受iterable对象,

Array.from(m.keys())    // [1, 2]Array.from(m.values())    // ["a", "b"]Array.from(m.entries())    // [[1, "a"], [2, "b"]]

(9)m.forEach(fn[, thisArg]),用于对Map以key的插入顺序进行遍历

m = new Map([[1, 'a'], [2, 'b']]);    // Map(2) {1 => "a", 2 => "b"}m.forEach((value, key)=>{    value    // "a", "b"    key      // 1, 2});

注:第一个参数是value,第二个参数才是key。

除了使用m.forEachMap还可以使用for ... of进行遍历,

m = new Map([[1, 'a'], [2, 'b']]);for(i of m){  i    // [1, 'a'], [2, 'b']}

4. key的相等性判断

Map key的相等性判断,使用了所谓的“SameValueZero”算法
(1)在做key的相等性判断时,NaN被认为与NaN相等。(即使NaN !== NaN
(2)其他种类的key,依据===运算符进行判断。
(3)目前+0-0被认为相等是符合ES2015规范的,但是会有浏览器兼容性问题。

5. Map与Object对比

(1)Object的key只能是字符串(String)或符号(Symbol),
Map的key可以是任意值,包括函数,对象(object)或者任何原始值(primitive value)。

(2)对于Map来说,可以通过size属性直接获取key的个数,
Object则需要Object.keys(xxx).length来间接获取自身属性的个数。

(3)Map实例是一个iterable对象,可以直接用来遍历,
Object需要先获取它的key,再使用key进行遍历。

(4)Object可以有原型对象,自身属性可能会无意间与原型属性相冲突。
(虽然ES2015中可以通过Object.create(null)来创建一个无原型的对象。)

(5)Map key的添加删除操作更加高效。

读到这里,这篇“js的Map函数怎么使用”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注编程网精选频道。

--结束END--

本文标题: js的Map函数怎么使用

本文链接: https://www.lsjlt.com/news/321812.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • js的Map函数怎么使用
    本文小编为大家详细介绍“js的Map函数怎么使用”,内容详细,步骤清晰,细节处理妥当,希望这篇“js的Map函数怎么使用”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。Map是ES2015引入的Global Obj...
    99+
    2023-06-29
  • js的Map函数使用方法详解
    Map是ES2015引入的Global Object,Map对象中保存了键值对,且任何对象(包括原始值)都可以作为键或者值。 1. 构造函数 Map必须作为构造函数来使用, new ...
    99+
    2024-04-02
  • java的map函数怎么使用
    在Java中,`Map`是一个接口,它表示键值对的映射。它有多个实现类,如`HashMap`,`TreeMap`等。要使用`Map`...
    99+
    2023-09-11
    java
  • js中map()函数的使用案例详解
    目录前言一、概念二、相关语法三、示例选择Object还是Map最后提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档 前言 关键词:map 项目中我们常常会遇到要对后端...
    99+
    2022-11-16
    js中map()函数的使用 js中使用map js map函数使用
  • 如何使用JS函数式编程Reduce与Map
    本篇内容主要讲解“如何使用JS函数式编程Reduce与Map”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用JS函数式编程Reduce与Map”吧!Jav...
    99+
    2024-04-02
  • Python高阶函数map()怎么使用
    这篇文章主要介绍了Python高阶函数map()怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Python高阶函数map()怎么使用文章都会有所收获,下面我们一起来看看吧。简介:格式:map(funct...
    99+
    2023-07-05
  • 怎么使用JS console.log函数
    这篇文章主要讲解了“怎么使用JS console.log函数”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用JS console.log函数”吧!1....
    99+
    2024-04-02
  • JS的递归函数怎么使用
    这篇文章主要介绍了JS的递归函数怎么使用的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇JS的递归函数怎么使用文章都会有所收获,下面我们一起来看看吧。编程语言中,函数Func(T...
    99+
    2024-04-02
  • 怎么使用js中hasOwnProperty函数
    这篇文章主要介绍“怎么使用js中hasOwnProperty函数”,在日常操作中,相信很多人在怎么使用js中hasOwnProperty函数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用js中hasO...
    99+
    2023-06-25
  • JavaScript中map函数怎么用
    这篇文章主要介绍了JavaScript中map函数怎么用,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。map 函数语法: var new_array = arr.m...
    99+
    2023-06-17
  •  js中toString()函数与valueOf()函数怎么使用
    本篇内容介绍了“ js中toString()函数与valueOf()函数怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!&n...
    99+
    2023-06-30
  • python如何使用map()函数
    这篇文章将为大家详细讲解有关python如何使用map()函数,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。map()map()是一个内置的Python函数,用于将一个函数应用于元素序列(如列表或字典)。...
    99+
    2023-06-03
  • JS周期函数setInterval怎么使用
    setInterval函数用于按照指定的时间间隔重复执行指定的代码块或函数。它接受两个参数,第一个参数是要执行的代码块或函数,第二个...
    99+
    2023-09-28
    JS
  • JS的异步函数async/await怎么使用
    这篇“JS的异步函数async/await怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“JS的异步函数async/a...
    99+
    2023-07-05
  • JS的Function与构造函数怎么使用
    这篇文章主要讲解了“JS的Function与构造函数怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“JS的Function与构造函数怎么使用”吧! 1.概述Function是...
    99+
    2023-06-21
  • 关于python中map函数的使用
    1. 概念 map函数也是python中的一个内置函数,用法同之前讲过的filter函数类似。map在这里的意思是映射的意思,会根据提供的函数对指定序列做映射。 map函数会返回一个...
    99+
    2023-05-16
    python map python map函数
  • Python中的map函数如何使用
    在Python中,map() 函数用于将一个函数应用到一个或多个可迭代对象的每个元素上,并返回一个将该函数应用到每个元素后的结果组成...
    99+
    2024-04-08
    python
  • JavaScript中内置函数Map()的使用
    目录Map()的定义和基础使用Map()的高级特性易于迭代所有元素易于检测元素是否存在易于删除元素具有可扩展的属性和方法Map()的使用场景缓存数据带键的循环翻译文本结论JavaSc...
    99+
    2023-05-20
    JavaScript Map() JavaScript Map
  • js异步函数async/awit怎么使用
    异步函数(async/await) 是一种用于处理 JavaScript 异步操作的语法糖,它建立在 Promise 基础之上,使得...
    99+
    2023-09-29
    js
  • Python中如何使用map函数
    Python中如何使用map函数,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。用法map(func, seq1[, seq2,…])map接收两个参数,第一个参数是函数名,...
    99+
    2023-06-04
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作