js map()处理数组和对象数据

    之前的文章梳理了JS数组与对象属性的遍历方法,本文介绍专门用以遍历并处理数据的map()方法。

一、原生map()

  map()是数组的一个方法,它创建一个新数组,其结果是该数组中的每个元素都调用一个提供的函数后返回的结果。map()里面的处理函数接受三个参数,分别指代当前元素、当前元素的索引、数组本身。(IE9以下不支持,对老旧浏览器的兼容性方法参考这里

/**** 原生map() ****/
var arrTmp = [1,2,3];
var arrDouble = arrTmp.map(function(num){
	return num*2;
})
// arrDouble -> [2,4,6]

//注意,使用map()时实际传递了3个参数:
arr.map(function(currentValue, index, array){
  // currentValue -> 数组中正在处理的当前元素
  // index -> 数组中正在处理的当前元素的索引
  // array -> 指向map方法被调用的数组
}) 

["1", "2", "3.5"].map(parseInt); // 结果不是[1, 2, 3],而是[1, NaN, NaN]
["1", "2", "3.5"].map(function(num){ return parseInt(num)}); //得到正确结果[1, 2, 3] 

//使用map()重组数组 
var kvArray = [{key: 1, value: 10}, {key: 2, value: 20}, {key: 3, value: 30}]; 
var reformattedArray = kvArray.map(function(obj) { var rObj = {}; rObj[obj.key] = obj.value; return rObj; }); 
// kvArray不变,reformattedArray -> [{1: 10}, {2: 20}, {3: 30}],

  

二、jQuery的$.map()

  $.map() 函数用于使用指定函数处理数组中的每个元素(或对象的每个属性),并将处理结果封装为新的数组返回。从 1.6 开始,该函数也支持遍历对象。它接受两个参数,分别是要处理的数组/对象和处理函数,其处理函数也接受键值和键名两个参数:

/**** jQuery $.map() ****/
// 筛选数组元素
var arrTmp = [1,2,3,4,5];
var bigNum = $.map(arrTmp,function(num){
	if(num>2){
		return num;
	}
});
// bigNum -> [3,4,5]

// 处理对象
var person = {
	jack:{age:9},
	tom:{age:20},
	bobo:{age:30}
}
var oldMan = $.map(person,function(value,key){
	if(value.age>26){
		return key;
	}
})
// oldMan -> ["bobo"]

 


更多专业前端知识,请上 【猿2048】www.mk2048.com
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
回答: 在JavaScript中,可以使用map方法对数组对象进行过滤。引用\[1\]中提供了几种方法来实现这个功能。方法一使用forEach遍历数组,通过splice方法删除满足条件的元素。方法二使用map方法,返回一个新的数组,将满足条件的元素替换为空字符串。方法三使用filter方法,返回一个新的数组,只包含不满足条件的元素。方法四使用Set,先将数组转为集合,再利用集合的差集操作来过滤数组对象。引用\[2\]中提供了一个简单的使用map方法过滤数组对象的示例代码。引用\[3\]中提供了另一种使用map方法过滤数组对象的示例代码。根据这些方法,你可以根据自己的需求选择合适的方法来过滤数组对象。 #### 引用[.reference_title] - *1* [Js数组过滤的方法](https://blog.csdn.net/weixin_46001062/article/details/125973866)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [js map方法应用场景 处理对象数组 筛选出指定字段数据](https://blog.csdn.net/ruoyan8899/article/details/124688459)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^koosearch_v1,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值