1、
function Foo() {
getName = function () { alert (1); };
return this;
}
Foo.getName = function () { alert (2);};
Foo.prototype.getName = function () { alert (3);};
var getName = function () { alert (4);};
function getName() { alert (5);}
//答案:
Foo.getName();//2 Foo代表的是一个名称空间,它的静态方法。
getName();//4 上下文作用域的一个方法
Foo().getName();//1 Foo()执行,其中的getName是语句,直接给getName赋值,而Foo函数中并没有此属性,因此向上层查找,找到后赋值,返回值this自然也指的是调用此函数的上下文作用域。
getName();//1 此时,它已经在上一句语句处理时被修改了
new Foo.getName();//2 .的优先级高于getName 相当于 new (Foo.getName)(),创造Foo.getName的实例。new关键字执行的操作:1.创建一个空对象,相当于{} 2.将空对象的_proto_属性和构造函数的原型链接起来 3.执行构造函数 4.返回对象。 因此这里会执行构造函数Foo.getName里的语句
new Foo().getName();//3 先创建Foo的实例,然后调用它的方法、实际上是原型方法
new new Foo().getName();//3 实例的实例,通过原型链继承,还是能访问原型方法
2、[“1”, “2”, “3”].map(parseInt) 答案是多少?
map(function(value,index,arr){});
parseInt(string,radix)//radix表示转换的进制0表示10进制,取值为2-36之间。
因此,这里相当于是在执行
parseInt("1",0);
parseInt("2",1);//radix不合法,因此返回NaN
parseInt("3",2);//这里是string与radix不匹配,因为一位2进制位只能为0或1
因此,答案为[1,NaN,NaN]