【Lodash源码】_.map() [ map和foreach有什么区别呢?]

本文通过实例对比分析Lodash库中的_.map()和_.forEach()方法,揭示它们在遍历数组时的共同点与不同点。_.forEach()不返回新数组,直接修改原数组;而_.map()返回新数组,保持原数组不变。在源码中,当传入参数为数组时,_.forEach()会调用arrayEach函数进行处理。
摘要由CSDN通过智能技术生成

我们通过例子来分析源码和两个方法之间的区别

举例:_.forEach()

var array = [1,2,3,4,5];  
var res = _.forEach(array, function (item,index,input) {  
       input[index] = item*10;  
})  
console.log(res);//=>undefined
console.log(array);//=>[10,20,30,40,50]

举例:_.map()

var res = _.map(array, function (item,index,input) {  
       input[index] = item*10;  
})  
console.log(res);//=>[10,20,30,40,50]
console.log(array);//=>[1,2,3,4,5]

共同点:

  1. 都是循环遍历数组中的每一项
  2. 每一次执行匿名函数都支持三个参数,数组中的当前项item,当前项的索引index,原始数组input
  3. 只能遍历数组

不同点:

_.foreach()

没有返回值

对原本数组进行操作

_.map()

有返回值

克隆原本数组 ,再新数组进行操作并返回新数组

?????我在敲黑板

这个同点,请自己在下面的源码中找到原因。

有兴趣交流的朋友,在下面留言

也可加微信群ÿ

在MyBatis中,可以使用foreach标签来遍历Map并进行更新操作。根据引用\[1\]和引用\[2\]的示例代码,可以看出在更新操作中,可以通过foreach标签遍历Map的key,并使用${key}来引用对应的value。具体的更新语句可以使用动态SQL的方式来构建。 例如,可以使用以下代码来实现批量更新操作: ```xml <update id="update" parameterType="java.util.Map"> UPDATE table_name <set> <foreach collection="map.keys" item="key" separator=","> ${key} = #{map\[key\]} </foreach> </set> WHERE condition </update> ``` 在这个例子中,通过foreach标签遍历Map的keys,然后使用${key}来引用对应的value,构建更新语句的SET部分。你可以根据实际情况修改表名、条件等。 希望这个回答对你有帮助! #### 引用[.reference_title] - *1* *2* [mybatis的使用及源码分析(十六) Mybatis使用foreach遍历Map](https://blog.csdn.net/u011943534/article/details/125738472)[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^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [Mybatis之foreach遍历Map实现](https://blog.csdn.net/it_lxg123/article/details/121370931)[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^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值