JavaScript 用new创建对象的过程(转)

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语句,还是返回新创建的对象。

posted @   yasepix  阅读(452)  评论(0编辑  收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示