js中new到底做了什么?如何重写new?
new 构造函数()执⾏顺序
1.在堆中开辟对象内存空间, 记为obj
内部信息2.在obj 中添加__proto__属性并指向构造函数.prototype
3.将构造函数中的this 指向obj
4.执⾏构造函数内语句
若构造函数中没有reutrn 或return this或基本类型(number、string、boolean、null、undefined)的值,则返回obj在堆中的内存地址;若return 引⽤类型,则返回值为这个引⽤类型
仿写new的⾏为
我学会function People(name, age, phone) {
this.name = name;
this.age = age;
this.phone = phone;
//若构造函数中`没有reutrn 或return this或基本类型`(number、string、boolean、null、undefined)的值,则返回obj在堆中的内存地址;若`return 引⽤类型`,则返回值为这个引⽤类型// return null;//⽆影响
// return {};//返回此对象
嘉奖申请// return function(){};//返回此函数争章
}
function _new(...args) {
let constructor = args[0];//获取构造函数
let obj = ate(constructor.prototype);//创建空对象,并将原型指向构造函数的原型
let res = constructor.call(obj, ...args.slice(1));//call强⾏将this指向第⼀个参数
if ((typeof res === 'object' || typeof res === 'function') && res != null) {
return res;好的句子摘抄
} el {
ps恢复默认设置return obj;
}
}
原始心管搏动let a = _new(People, 'aa', 20, 132456);
let na = new People('aa', 20, 132456);
console.log(a, na);
//运⾏结果
People { name: 'aa', age: 20, phone: 132456 }构建和谐
People { name: 'aa', age: 20, phone: 132456 }