lodash源码分析之invokeMap
本文为读 lodash 源码的第一百五十篇,后续文章会更新到这个仓库中,欢迎 star:pocket-lodash
gitbook也会同步仓库的更新,gitbook地址:pocket-lodash
依赖
import baseEach from './.internal/baseEach.js'
import invoke from './invoke.js'
import isArrayLike from './isArrayLike.js'
《lodash源码分析之baseEach》 《lodash源码分析之invoke》 《lodash源码分析之isArrayLike》
源码分析
invokeMap 会调用 path 上的方法处理 collection 上的每个元素,返回一个数组,包含每次调用的结果。如果 path 是一个函数,则每次调用的时候,this 指向的是当前的元素。
源码如下:
function invokeMap(collection, path, args) {
let index = -1
const isFunc = typeof path === 'function'
const result = isArrayLike(collection) ? new Array(collection.length) : []
baseEach(collection, (value) => {
result[++index] = isFunc ? path.apply(value, args) : invoke(value, path, args)
})
return result
}
如果 collection 是一个类数组,则初始化一个长度为 length 的数组作为结果集 result ,否则初始化一个空数组。
然后调用 baseEach 来遍历 collection ,path 如果是函数,则通过 apply 来调用,this 绑定到当前元素 value ,如果 path 是属性路径,则直接调用 invoke 方法,得到的结果存入结果集 result 中。
License
署名-非商业性使用-禁止演绎 4.0 国际 (CC BY-NC-ND 4.0)
最后,所有文章都会同步发送到微信公众号上,欢迎关注,欢迎提意见:
作者:对角另一面