函数创建对象的几种模式(仅为个人整理,如有差错望指正)

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了函数创建对象的几种模式(仅为个人整理,如有差错望指正)相关的知识,希望对你有一定的参考价值。

1.工厂模式:

function creatPerson(name,age,job){
            var o=new Objact();
            o.name=name;
            o.age=age;
            o.job=job;
           o.sayName=function(){
              aert(this.name);
        }
          return o;
}
var person1=createPerson("lee",29,"Engineer");
var person2=createPerson("jake",30,"Doctor");          

缺点:无法解决对象识别问题。

2.函数构造模式:

function Person(name,age,job){
               this.name=name;
               this.age=age;
               this.job=job; 
         this.sayName=function(){
              alert(this.name);            
  };
}
   var person1=new Person("lee",29,"Engineer");
   var person2=new Person("jack",30,"Doctor");

注意:  函数名首字母大写;必须用new操作符创建对象;构造模式中没有明显的创建对象,直接将属性和方法赋值给了this对象;没有return语句;可通过instanceof操作符区分对象实例;

          创建Person的新实例,必须使用new操作符,用直这种方式调用构造函数会经历一下4步:

                    1.创建一个新对象;

                    2.将构造函数的作用域赋给新对象(this指向 新对象);

                    3.执行构造函数中的代码;

                    4.返回新对象;

缺点:以上代码每个方法都要在每个实例上重新创建一遍

 

以上是关于函数创建对象的几种模式(仅为个人整理,如有差错望指正)的主要内容,如果未能解决你的问题,请参考以下文章

js创建对象的几种方式(工厂模式构造函数模式原型模式)

js创建对象的几种方式(工厂模式构造函数模式原型模式)

创建对象的几种方式和对象方法

爱创课堂每日一题第五十八天-javascript对象的几种创建方式

[ES6] js创建对象的几种方法 字面式创建对象 工厂模式 构造函数模式 prototype __ proto __ 对象访问机制

javascript对象的几种创建方式