JavaScript function overloading
This is an example of function overloading in JavaScript
http://ejohn.org/blog/javascript-method-overloading/
function _add(object, name, fn){
var old = object[ name ];
if ( old )
object[ name ] = function(){
if ( fn.length == arguments.length )
return fn.apply( this, arguments );
else if ( typeof old == 'function' )
return old.apply( this, arguments );
};
else
object[ name ] = fn;
}
Now use the function overloading
function Users(){}
_add(Users.prototype, "find", function(){
// Find all users...
});
_add(Users.prototype, "find", function(name){
// Find a user by name
});
_add(Users.prototype, "find", function(first, last){
// Find a user by first and last name
});
var users = new Users();
users.find(); // Finds all
users.find("John"); // Finds users by name
Written by Steven Anavay
Related protips
2 Responses
data:image/s3,"s3://crabby-images/8ad90/8ad90029abe5560fea6dca55a7bb225c254083b2" alt=""
For me, this technique is harder to read over putting the logic to inpsect the arguments
array inside your object's function, and then make decisions on the logic to apply. I might use a closure like this:
(function(){
function findAll() {
// Find all users...
}
function findByFullName(name) {
// Find a user by name
}
function findBySurname(first, last) {
// Find a user by first and last name
}
Users.prototype.find = function find() {
if (arguments.length === 0)
return findAll.apply(this);
if (arguments.length === 1 and typeof(arguments[1]) === 'string')
return findByFullName.apply(this, arguments);
// by default, search using first and last name
return findBySurname.apply(this, arguments);
}
})();
over 1 year ago
·
data:image/s3,"s3://crabby-images/1bddf/1bddfe81ebdd2bb6fabe741e39c42d0259cc7d4e" alt=""
Thanks Steve,
I think your version is really nice. I am going to give it a try and might change to this approach in the future.
over 1 year ago
·
Have a fresh tip? Share with Coderwall community!
Post
Post a tip
Best
#Function
Authors
data:image/s3,"s3://crabby-images/28f69/28f695f7e59bc47fd71f8ba4cc7ae74ab525809f" alt=""
Chip Castle
21.7K
data:image/s3,"s3://crabby-images/ba3fc/ba3fc6df1bf89edb0172907a836653e7e12d404e" alt=""
deleteman
10.11K
Sponsored by #native_company# — Learn More
#native_title#
#native_desc#