Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

lodash源码分析之invokeMap #151

Open
HeftyKoo opened this issue Mar 24, 2020 · 0 comments
Open

lodash源码分析之invokeMap #151

HeftyKoo opened this issue Mar 24, 2020 · 0 comments
Labels
api 暴露出来的接口 系列文章

Comments

@HeftyKoo
Copy link
Owner

本文为读 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)

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

作者:对角另一面

@HeftyKoo HeftyKoo added 系列文章 api 暴露出来的接口 labels Mar 24, 2020
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
api 暴露出来的接口 系列文章
Projects
None yet
Development

No branches or pull requests

1 participant