What does the lodash flow function do?

心已入冬 提交于 2019-12-23 07:47:51

问题


I am reading some code that uses _.flow() from lodash and the explanation in the docs just isn't making sense to me.

The doc says

Creates a function that returns the result of invoking the given functions with the this binding of the created function, where each successive invocation is supplied the return value of the previous.

With the example:

function square(n) {
  return n * n;
}

var addSquare = _.flow([_.add, square]);
addSquare(1, 2);
// => 9

I have read this a few times and I can not work out what it means or how that function returns 9. The closest think I can think of is folding in functional programming but this doesn't look like that. Is there any alternative way of explaining what flow does?


回答1:


Rewording the definition from the docs in simpler terms: It calls, in order, the methods in the array. It uses the result from each function as the parameters for the next function. In the case of the example given, the steps are as follows:

  1. Invokes _.add(1, 2), which returns 3.
  2. Passes that return value as the parameter to the next function in the array, which becomes square(3). This returns 9.



回答2:


Here is the relevant part of the source code for this function:

return function(...args) {
    let index = 0
    let result = length ? funcs[index].apply(this, args) : args[0]
    while (++index < length) {
        result = funcs[index].call(this, result)
    }
    return result
}

So it first applies the first function to the input arguments; then calls the rest of the functions with each taking up the result of the previous stage.

I can see the following benefits from doing it this way: - All the applied functions will use the this argument of the caller in case that is desired. - On definition, it just returns a function. This allows for lazy evaluation. The flow function can be passed around. The actual calculation will take place only when it is applied to the arguments.



来源:https://stackoverflow.com/questions/53510145/what-does-the-lodash-flow-function-do

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!