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?
Lodash is a popular javascript based library which provides 200+ functions to facilitate web development. It provides helper functions like map, filter, invoke as well as function binding, javascript templating, deep equality checks, creating indexes and so on.
throttle() method in lodash is used to create a throttled function that can only call the func parameter maximally once per every wait milliseconds.
Lodash is a JavaScript utility library. It provides a variety of functions for manipulating arrays, objects, strings, and numbers. ( source: Lodash) Since Lodash is written in Javascript, we can use it in any React application. Using Lodash in your React application is a simple and straightforward process.
Lodash's `merge()` Function Given two objects destination and source , Lodash's merge() function copies the 2nd object's own properties and inherited properties into the first object.
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:
_.add(1, 2)
, which returns 3
.square(3)
. This returns 9
.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.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With