理解new对象过程,需要提前了解原型及原型链的相关知识
我们都知道,JS当中创建对象使用的是原型设计模式,即使用new操作符调用构造函数
这里先看一个例子:
function Person(name,sex){
this.name = name;
this.sex = sex;
};
Person.prototype.go = function(){
return this.name;
}
var p = new Person('金文','男');
这个过程可以分为4个步骤,具体如下:
①创建一个新的对象
var obj = {};
②把该对象的__proto__属性设置为构造函数的prototype属性,即完成原型链
obj.__proto__ = Person.prototype;
③执行构造函数中的代码,构造函数中的this指向该对象(obj)
obj.name = '金文';
obj.sex = '男';
obj.go = function(){return '金文';}
④返回该对象obj;
var obj = {
name:'金文',
sex:'男',
go:function(){
return '金文';
}
}
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。