js es6系列——map

Posted 你永远想象不到,一个光鲜亮丽的Application,有多么

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了js es6系列——map相关的知识,希望对你有一定的参考价值。

正文

map,必要解释就是map不是地图的意思,而是映射的意思。

这里就简单的介绍了这个map了。

array.map(callback,[ thisObject]);

看下这个案例后,我们发现了就发现了一个问题。

以前呢,我写道:map是一个过滤器,其实是将filter弄混了,当然我也介绍过filter。

那么什么是映射呢?

这个时候数学似乎显得非常重要了,来看下定义:

两个非空集合A与B间存在着对应关系f,而且对于A中的每一个元素x,B中总有有唯一的一个元素y与它对应,就这种对应为从A到B的映射,记作f:A→B。其中,b称为元素a在映射f下的象,记作:b=f(a)。a称为b关于映射f的原象。

集合A中所有元素的象的集合称为映射f的值域,记作f(A)。

映射,或者射影,在数学及相关的领域还用于定义函数。函数是从非空数集到非空数集的映射,而且只能是一对一映射或多对一映射。

ok,这下明白了吧。

在实际使用的时候,我们可以利用map方法方便获得对象数组中的特定属性值们。例如下面这个例子(之后的兼容demo也是该例子):

var users = [
{name: "张含韵", "email": "zhang@email.com"},
{name: "江一燕", "email": "jiang@email.com"},
{name: "李小璐", "email": "li@email.com"}
];

var emails = users.map(function (user) { return user.email; });

console.log(emails.join(", ")); // zhang@email.com, jiang@email.com, li@email.com

Array.prototype扩展可以让IE6-IE8浏览器也支持map方法:

if (typeof Array.prototype.map != "function") {
  Array.prototype.map = function (fn, context) {
    var arr = [];
    if (typeof fn === "function") {
      for (var k = 0, length = this.length; k < length; k++) {      
         arr.push(fn.call(context, this[k], k, this));
      }
    }
    return arr;
  };
}




以上是关于js es6系列——map的主要内容,如果未能解决你的问题,请参考以下文章

peptide map DDA和IMS有啥区别

js 基础概念系列1

js es6 map 与 原生对象区别

[js高手之路] es6系列教程 - 迭代器,生成器,for...of,entries,values,keys等详解

ES6笔记-- SetMap结构和Iterator迭代器

JS中的数据类型,包含ES6,set和map等等