function Foo() {
getName = function () { console.log(1); };//未使用var声明,相当于全局赋值
return this;
}
Foo.getName = function () { console.log (2);};//函数静态方法,无需实例化即可调用
Foo.prototype.getName = function () { console.log (3);};
var getName = function () { console.log (4);};//会覆盖函数声明
function getName() { console.log (5);}//函数声明会提升
//请写出以下输出结果:
Foo.getName();//2, 解析:调用函数静态方法
this.getName();//4 调用全局getName函数
getName();//4, 解析:函数声明提升
Foo().getName();//1, 解析:Foo().getName() 可以转化为this.getName()。Foo函数中的getName未使用var声明,故而会赋值给全局的getName,this.getName会调用全局的函数
getName();//1, 解析:参见上一步
new Foo.getName();//2 解析:主要考察js执行的优先级,下面两步也是同样的思路
new Foo().getName();//3 解析:实例化Foo, getName函数在其他地方没有定义,只能在prototype上去查找
new new Foo().getName();//3
链接地址:详解在这里