码迷,mamicode.com
首页 > 编程语言 > 详细

JavaScript 用new创建对象的过程

时间:2015-07-02 23:52:34      阅读:179      评论:0      收藏:0      [点我收藏+]

标签:

   在JavaScript中创建自定义对象都需要用new运算符,那么创建对象的过程是什么样的呢?

例如现在有如下构造函数:

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中它表现为__pro__

3.call构造函数的内部方法,把其中的this赋值为新创建的对象obj,并传入所需参数。

4.执行构造函数,并返回创建的对象。

这里有一点需要说明: 正常来讲构造函数中是不用写return语句的,因为它会默认返回新创建的对象。但是,如果在构造函数中写了return语句,如果return的是一个对象,那么函数就会覆盖掉新创建的对象,而返回此对象;如果return的是基本类型如字符串、数字、布尔值等,那么函数会忽略掉return语句,还是返回新创建的对象。

JavaScript 用new创建对象的过程

标签:

原文地址:http://www.cnblogs.com/kongxy/p/4617343.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!