This article needs additional citations for verification. Please help improve this article by adding citations to reliable sources. Unsourced material may be challenged and removed. Find sources: "Method chaining" – news · newspapers · books · scholar · JSTOR (May 2008) (Learn how and when to remove this message) |
Method chaining is a common syntax for invoking multiple method calls in object-oriented programming languages. Each method returns an object, allowing the calls to be chained together in a single statement without requiring variables to store the intermediate results.
Rationale
Local variable declarations are syntactic sugar.
Method chaining eliminates an extra variable for each intermediate step. The developer is saved from the cognitive burden of naming the variable and keeping the variable in mind.
Method chaining has been referred to as producing a "train wreck" due to the increase in the number of methods that come one after another in the same line that occurs as more methods are chained together.
A similar syntax is method cascading, where after the method call the expression evaluates to the current object, not the return value of the method. Cascading can be implemented using method chaining by having the method return the current object itself. Cascading is a key technique in fluent interfaces, and since chaining is widely implemented in object-oriented languages while cascading isn't, this form of "cascading-by-chaining by returning this" is often referred to simply as "chaining". Both chaining and cascading come from the Smalltalk language.
While chaining is syntax, it has semantic consequences, namely that requires methods to return an object, and if implementing cascading via chaining, this must be the current object. This prevents the return value from being used for some other purpose, such as returning an error value.
Examples
A common example is iostream in C++, where for example <<
returns the left object, allowing chaining.
Compare:
a << b << c;
equivalent to:
a << b; a << c;
Another example in JavaScript uses the built-in methods of Array:
filter somethings .filter(x => x.count > 10) .sort((a, b) => a.count - b.count) .map(x => x.name)
Note that in JavaScript filter
and map
return a new shallow copy of the preceding array but sort
operates in place. To get a similar behavior, toSorted
may be used. But in this particular case, sort
operates on the new array returned from filter
and therefore does not change the original array.
See also
References
- "Applying Method Chaining". First Class Thoughts. Archived from the original on 2011-02-22. Retrieved 2011-04-13.
In order to simplify repeated object interactions on the same object the old trick Method Chaining originating the world of Smalltalk should be enforced. The idea is to let methods return
this
rather thanvoid
, thus affecting especiallyset()
andadd()
methods. Method chaining arose during the designers of Smalltalk pursuit to minimize the number of keywords in the language, which lead to the discovery thatvoid
is an unnecessary keyword!. - "CMSC 631 – Program Analysis and Understanding" (PDF).
• Syntactic sugar for local declarations - let x = e1 in e2 is short for (λx.e2) e1
- Martin, Robert Cecil (2008). Clean Code: A Handbook of Agile Software Craftsmanship. Prentice Hall. ISBN 978-0-13-235088-4.