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 版权协议,转载请附上原文出处链接和本声明。