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介绍。
- 提示下载完但解压或打开不了?
- 找不到素材资源介绍文章里的示例图片?
- 模板不会安装或需要功能定制以及二次开发?
 
                     
     
        
       
        
       
    
发表评论
还没有评论,快来抢沙发吧!