new操作符干了啥?
如下
var F=function(){
//this指向谁,在定义时是不知道的
};
var p=new F;
做了这四步:
1.创建一个空的对象就是
p={}
或者p=new Object
2.设置原型链
p.proto=F.prototype;
就是把构造函数的prototype属性给了实例的proto属性。
3.让F中的this指向实例p,执行F的函数体。
4.判断F的返回值类型:
换种说法
(1) 首先, 当我们使用new操作符时, js会先创建一个空的对象;
(2) 然后, 构造函数中的this指向该空对象;
(3) 其次, 在构造函数中通过操作this, 来给这个空对象赋予相应的属性;
(4) 最后, 返回这个经过处理的"空对象"(此时, 对象已经不是空的了).
(1) 如果构造函数的返回值是一个原始类型(非引用对象, 如字符串)
,那么返回值为new创建的"空对象", 如:
var obj = new Function() {
return "code";};
alert(obj); // [object object]
(2) 如果构造函数的返回值是一个引用对象(数组, 对象, 函数等),
那么返回值会覆盖new创建的"空对象", 如:
var obj = new Function() {
return new String("code"); };
alert(obj); // "code"