Skip to content

Latest commit

 

History

History
48 lines (32 loc) · 1.99 KB

invokeMap.md

File metadata and controls

48 lines (32 loc) · 1.99 KB

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 来遍历 collectionpath 如果是函数,则通过 apply 来调用,this 绑定到当前元素 value ,如果 path 是属性路径,则直接调用 invoke 方法,得到的结果存入结果集 result 中。

License

署名-非商业性使用-禁止演绎 4.0 国际 (CC BY-NC-ND 4.0)

最后,所有文章都会同步发送到微信公众号上,欢迎关注,欢迎提意见:

作者:对角另一面