JS基础 map 与 filter

参考

  1. 菜鸟教程:map
  2. 菜鸟教程:filter

1、区别与相似点

相似点:

  • map与filter都是用于无修改 遍历
  • 不会对空数组进行检测。
  • 不会改变原始数组。
  • 创建一个新的数组,

区别:
map() 方法返回一个新数组,新数组中的元素为原始数组元素调用函数处理后的值
filter() 方法创建一个新的数组,新数组中的元素是通过检查指定数组中符合条件的所有元素。

2、具体

2.1 map

newArray = Array.map(function(currentValue,index,Array){
		return value
},thisValue)

//返回一个新数组,数组中的元素为原始数组元素调用函数处理后的值。

var numbers = [65, 44, 12, 4];

function multiplyArrayElement(num) {
    return num * document.getElementById("multiplyWith").value;//value
}

function myFunction() {
    document.getElementById("demo").innerHTML = numbers.map(multiplyArrayElement);
}

2.2 filter

newArray = Object.filter(function(value,index){
return true/false
})

//true的值被添加到newArray中

var ages = [32, 33, 16, 40];

function checkAdult(age) {
    return age >= 18;
}

function myFunction() {
    document.getElementById("demo").innerHTML = ages.filter(checkAdult);
}

3、使用场景

3.1 map 再创

3.2 filter 筛选

期待批评指正!

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaScript中的mapfilter是数组的两种常用方法。 map方法是用于遍历数组的每个元素,并将每个元素通过一个回调函数进行处理后返回一个新的数组。通过map方法,我们可以对原数组的每个元素进行相同的操作,并将结果存储在新的数组中。例如,我们可以使用map方法将一个数组中的每个元素都加倍。 filter方法是用于筛选数组中符合条件的元素而返回一个新的数组。通过filter方法,我们可以根据指定的条件筛选出符合条件的元素,并将它们存储在新的数组中。例如,我们可以使用filter方法筛选出一个年龄数组中所有大于等于18岁的成年人。 这两个方法在实际应用中有不同的使用场景。map方法常用于对数组中的每个元素进行相同的操作,例如对数组中的数字进行计算或对字符串进行处理。而filter方法常用于从数组中筛选出符合某个条件的元素,例如筛选出符合特定条件的对象或字符串。 需要注意的是,这两个方法都会返回一个新的数组,而不会修改原始数组。因此,在使用这两个方法时,我们可以放心地进行操作而不会对原始数据造成影响。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [JavaScript遍历数组的三种方法map、forEach与filter实例详解](https://download.csdn.net/download/weixin_38596093/12945825)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [JS基础 mapfilter](https://blog.csdn.net/qq_42676176/article/details/125474869)[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^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值