new的过程

https://blog.csdn.net/weixin_43276913/article/details/105597983
javascript中在new一个对象时发生了什么?

1.创建一个新对象

2.将新对象的__proto__指向构造函数原型,也就是将新对象链接到原型链上

3.将构造函数中的this指向新对象

4.构造函数中若有返回值,就直接返回;否则返回新对象


以构造器的prototype属性为原型,创建新对象;
• 将this(也就是上一句中的新对象)和调用参数传给构造器,执行;
• 如果构造器没有手动返回对象,则返回第一步创建的新对象,如果有,则舍弃掉第一步创建的新对象,返回手动return的对象。

function Person(name, age){
    this.name = name;
    this.age = age;
}
 
Person.prototype.sayhi = function(){
    console.log('hi', this.name)
}
 
function _new() {
    let o = {};
    let _self = Array.from(arguments).slice(0, 1)[0];
    let _args = Array.from(arguments).slice(1);
    o.__proto__ = _self.prototype;
    _self.apply(o, _args);
    return o;
}
 
var p = _new(Person, 'lucy', 12);
p.sayhi(); // hi, lucy
 

版权声明:本文为w_gold_qin原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
THE END
< <上一篇
下一篇>>