本文共 970 字,大约阅读时间需要 3 分钟。
new关键字的作用
通过new关键字实例化构造函数,获取对象。
在JavaScript中,new关键字用于创建一个对象,这个对象是通过调用构造函数实现的。构造函数执行后,会返回一个新的对象,这个对象会继承构造函数原型链上的属性和方法。
以下是一个简单的示例:
<script> function Person(name) { this.name = name; this.say = function() { console.log(this.name); } } Person.prototype.age = '18'; Person.prototype.sayYes = function() { console.log('yyy'); } </script>
let p = new Person('小明'); console.log(p);
通过new关键字实例化的对象p,具备了构造函数Person中this的属性:name,也具备了构造函数Person的原型prototype的属性age和方法sayYes。
实现过程
当使用new关键字调用构造函数时,JavaScript会执行以下步骤:
创建一个空对象,并且this变量引用该对象,同时还继承了该函数的原型。 原型的属性和方法被加入到this引用的对象中。原型的执行,确定对象obj的原型链。 新创建的对象由this所引用,并且最后隐士的返回this。绑定this对象为obj,传入参数;执行person构造函数,进行属性和方法的赋值操作。 返回结果。注意:在通过该种方式获取对象时,最终不一定返回的是对象o,要看构造函数的返回值是什么。如果函数返回的是基本类型值,实际会生成一个对象,返回o。如果是函数返回的是引用类型值,则实际返回的是该引用类型值。 例如,以下代码展示了通过new关键字实例化对象的过程:
var obj = {}; obj.__proto__ = Person.prototype; person.call(obj, '小明');
在这个过程中,obj会被作为this对象绑定,并传入参数'小明'执行person构造函数。执行后,person.call返回的结果是obj,即为new关键字创建的对象p。该对象会具备Person构造函数赋予的属性和方法。
转载地址:http://iycp.baihongyu.com/