JavaScript实现new

45 阅读1分钟
<!DOCTYPE html>
<html lang="zh-CN">
<head>
  <meta charset="UTF-8">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>Document</title>
</head>
<body>
  <script>
    //实现new 
    //传过来一个构造方法名,和一些value值
    function myNew(constructor,...args){
      //1.创建一个新的对象,并将这个对象的__proto__指向构造函数的原型对象上
      const obj = Object.create(constructor.prototype) 
      //2.执行构造函数,并将里面的this指向改成新创建的对象
      const result = constructor.apply(obj,args)
      //3.如果上一步返回的是一个对象那就返回上一步的对象,如果不是一个对象就返回刚创建的对象.
      return result instanceof Object ? result : obj
      //注:只管构造函数中返回的是不是对象,其余的一律忽略.
    }

    function Person(name,age){
      this.name = name;
      this.age = age;
      return {text:"欢迎"}
    }

    const myy = myNew(Person,"苗",24)
    console.log(myy);

  </script>
</body>
</html>