函数创建对象的几种模式(仅为个人整理,如有差错望指正)
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.返回新对象;
缺点:以上代码每个方法都要在每个实例上重新创建一遍
以上是关于函数创建对象的几种模式(仅为个人整理,如有差错望指正)的主要内容,如果未能解决你的问题,请参考以下文章
爱创课堂每日一题第五十八天-javascript对象的几种创建方式
[ES6] js创建对象的几种方法 字面式创建对象 工厂模式 构造函数模式 prototype __ proto __ 对象访问机制