On 28/03/2005 09:31, John Smith wrote:
can we overload a javascript function with different argument?
example:
function a(a){}
function a(a,b){}
Not in the way other languages define method overloading, no. In the
case above, the function object created by the first function
declaration would immediately be replaced by the second.
There are a few approaches that can be useful, depending on what
you're trying to achieve. You give no details so I'll provide a quick
run through them and you can determine which is best. I'll apologise
now for the exceedingly artifical examples. :/
1) Optional arguments
If a method is defined as taking optional arguments, you can add
the defaults by taking advantage of ECMAScript's rather different
logical OR (||) operator:
function myFunction(a, b) {
b = b || 'default';
}
If the argument, b, evaluates to false (that is, zero (0), empty
string (''), null, undefined, or false), the second operand will
be assigned in its place.
If one of these "false" values is legal, but not the default, see
(3) for an alternative.
2) Overloading by number of arguments
The arguments object available within all functions contains all
arguments passed to the function as properties, and the number of
arguments in its length property. You can use the value of the
latter to change the behaviour of the function, and the former to
access any arguments that do not have a corresponding formal
identifier.
function myFunction() {var msg;
if(arguments.length) {
msg = arguments.length + ' arguments passed:\n';
for(var i = 0, n = arguments.length; i < n; ++i) {
msg += '\n' + arguments[i];
}
} else {
msg = 'No arguments passed!';
}
alert(msg);
}
3) Overloading by type of arguments
I sometimes use this approach when I want to allow a function to
take either a reference to an element, or its id attribute value.
You can examine the type of the argument using the typeof
operator:
function myFunction(element) {
if('string' == typeof element) {
element = document.getElementById(element);
}
if(element) {
/* ... */
}
}
If a function is called and an argument doesn't have a corresponding
value, it will be undefined with typeof evaluating to the string,
'undefined'. Returning to the example in (1), you might have an
argument which expects an integer. If the argument was unspecified,
you might want it to assume the value -1, but zero is legal. In that
case,
function myFunction(a, b) {
if('undefined' == typeof b) {b = -1;}
}
Hope that helps,
Mike
--
Michael Winter
Replace ".invalid" with ".uk" to reply by e-mail.