看下面js代码
[b]运行结果[/b]
function Double(value) { dwn(arguments.callee); dwn(this.constructor); return parseFloat(value); }
function Double(value) { dwn(arguments.callee); dwn(this.constructor); return parseFloat(value); }
function Double(value) { dwn(arguments.callee); dwn(this.constructor); return parseFloat(value); }
undefined
[object Object]
34.32
[b]说明:[/b]
this.constructor的值为 构造函数(如果被当作一个构造函数的话);如果用普通方法调用时,它的值为undefined
arguments.callee用来引用当前正在执行的函数。
所以可以通过这两个语法特性在函数里判断是哪种调用
[b]结果:[/b]
构造函数:1243.34
普通函数:34.32
function dwn(s)
{
document.write(s + "<br/>");
}
function Double(value)
{
dwn(arguments.callee);
dwn(this.constructor);
return parseFloat(value);
}
var d1 = new Double(1243.34);
var d2 = Double(34.32);
dwn(d1);
dwn(d2);
[b]运行结果[/b]
function Double(value) { dwn(arguments.callee); dwn(this.constructor); return parseFloat(value); }
function Double(value) { dwn(arguments.callee); dwn(this.constructor); return parseFloat(value); }
function Double(value) { dwn(arguments.callee); dwn(this.constructor); return parseFloat(value); }
undefined
[object Object]
34.32
[b]说明:[/b]
this.constructor的值为 构造函数(如果被当作一个构造函数的话);如果用普通方法调用时,它的值为undefined
arguments.callee用来引用当前正在执行的函数。
所以可以通过这两个语法特性在函数里判断是哪种调用
function Double2(value)
{
value = parseFloat(value);
if (this.constructor == arguments.callee)
{
this.valueOf = this.toString = function()
{
return "构造函数:" + value;
}
}
else
{
return "普通函数:" + value;
}
}
var d3 = new Double2(1243.34);
var d4 = Double2(34.32);
dwn(d3);
dwn(d4);
[b]结果:[/b]
构造函数:1243.34
普通函数:34.32