欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  web前端

详解模拟一个js new一个对象的过程代码

程序员文章站 2022-06-04 14:48:49
...
这篇文章介绍详解模拟一个js new一个对象的过程代码
        function Person(){
          this.name=1234;
         // return {};
          }
        Person.prototype.getname=function(){
            console.log(this.name);
            }
        function CreateObj(){
           var fn=[].shift.call(arguments);
           var args=arguments;
           var obj=new Object();
           var ret=fn.apply(obj,args);
           obj.__proto__=fn.prototype;
           return typeof ret ==='object'?ret:obj;
           }
    var a=CreateObj(Person);
    console.log(a);

上述代码CreateObj 模拟了js new一个对象的过程,从该函数的代码中可以清晰的看到一个对象是怎么生成的,从这里我们也可以发现,如果构造函数显示的返回一个对象,new出来的对象就是该构造函数返回的对象,如果retrun其他类型的数据都会被new忽略。

以上就是详解模拟一个js new一个对象的过程代码的详细内容,更多请关注其它相关文章!

相关标签: javascript