JavaScript 用new创建对象的过程
在JavaScript中创建自定义对象都需要用new运算符,那么创建对象的过程是什么样的呢?
例如现在有如下构造函数:
1
2
3
4
5
6
7
8
9
|
function Person(name) { this .name = name; } Person.prototype = { constructor: Person, sayName: function () { alert( this .name); }; var jack = new Person( "Jack" ); |
首先,必须保证new运算符后跟着的是一个有[[Construct]]内部方法的对象,否则会抛出异常。
接下来就是创建对象的过程:
1.先创建一个原生对象,假定为obj = {}或obj = new Object,。
2.获得构造函数Person的prototype对象,并将其赋给obj的[[Prototype]]属性。在firefox中它表现为__proto__
3.call构造函数的内部方法,把其中的this赋值为新创建的对象obj,并传入所需参数。
4.执行构造函数,并返回创建的对象。
这里有一点需要说明: 正常来讲构造函数中是不用写return语句的,因为它会默认返回新创建的对象。但是,如果在构造函数中写了return语句,如果return的是一个对象,那么函数就会覆盖掉新创建的对象,而返回此对象;如果return的是基本类型如字符串、数字、布尔值等,那么函数会忽略掉return语句,还是返回新创建的对象。