JavaScript中使用 arguments 模拟重载
在JavaScript 中,每个函数内部可以使用 arguments 对象,该对象包含了函数被调用时的实际参数值。
arguments 对象虽然在功能上与数组有些类似,但它不是数组。arguments 对象与数组的类似体现在它有一个length 属性,同时实际参数的值可以通过[]操作符来获取,但arguments 对象并没有数组可以使用的push 、pop 、splice 等方法。其原因是arguments 对象的prototype 指向的是Object. prototype, 而不是Array. prototype 。
Java 和C+ +语言都支持方法重载,即允许出现名称相同而形式参数不同的方法,但JavaScript 并不支持这种方式的重载。这是因为JavaScript 中的function 对象也是以属性的形式出现的,在一个对象中增加与已有function 同名的新function 时,旧的function 对象会被覆盖。不过可以通过使用arguments 来模拟重载,其实现机制是通过判断arguments 中实际参数的个数和类型来执行不同的逻辑。
function sayHello() {
switch (arguments.length) {
case 0:
return "Hello";
case 1 :
return "Hello, " + arguments[0];
case 2:
return (arguments[1] == "en" ? "你好," : "Hello, ") + arguments [0];
}
},
sayHello () ;
sayHello("Alex");
sayHello("Alex", "cn");
callee 是arguments 对象的一个属性,其值是当前正在执行的function 对象。它的作用 是使匿名function 可以被递归调用。下面以一段计算斐波那契序列中第N 个数的值的过程来 演示arguments.callee 的使用。
function fibonacci (num) {
return (function (num) {
if (typeof num !== "number") return -1;
num = parseInt(num);
if(num < 1) return -1;
if (num == 1 || num == 2) return 1;
return arguments.callee(num - 1) + arguments.callee(num - 2);
}) (num);
}
fibonacci(100);
|