new
new 做了什么
- 创建了一个全新的对象
- 实例与构造函数通过原型链链接了起来
- 将空对象作为构造函数的this上下文,执行构造函数
- 返回新对象
实现一个new
function testNew (fn) {
// 获取传入的参数;
const args = [].slice.call(arguments, 1);
// 新建一个对象
const newObj = {};
// 把这个对象与构造函数的原型对接
Object.setPrototypeOf(newObj, fn.prototype)
// this指向新对象
fn.apply(newObj, args);
// 返回这个对象
return newObj
}
对比下看
function Person(name) {
this.name = name
}
const obj = new Person('你好')
function testNew (fn) {
// 获取传入的参数;
const args = [].slice.call(arguments, 1);
// 新建一个对象
const newObj = {};
// 把这个对象与构造函数的原型对接
Object.setPrototypeOf(newObj, fn.prototype)
// this指向新对象
fn.apply(newObj, args);
// 返回这个对象
return newObj
}
const testObj = testNew(Person, '我好啊')
console.log(obj, testObj, '测试');
一模一样有木有
但是要注意如果构造函数中返回了一个对象那么new了之后返回的就是构造函数的对象,所以我们还是要再改动下
function testNew (fn) {
// 获取传入的参数;
const args = [].slice.call(arguments, 1);
// 新建一个对象
const newObj = {};
// 把这个对象与构造函数的原型对接
Object.setPrototypeOf(newObj, fn.prototype)
// this指向新对象
const fnObj = fn.apply(newObj, args);
// 返回这个对象
return fnObj instanceof Object ? fnObj : newObj;
}
常见问题FAQ
- 免费下载或者VIP会员专享资源能否直接商用?
- 本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
- 提示下载完但解压或打开不了?
- 找不到素材资源介绍文章里的示例图片?
- 模板不会安装或需要功能定制以及二次开发?
发表评论
还没有评论,快来抢沙发吧!