一、工厂方式可以为一个对象,创建多个实例。

  1. var oCar = new Object;
  2. oCar.color = "red";
  3. oCar.doors=4;
  4. oCar.mpg=23;
  5. oCar.showColor = function(){
  6. alert(this.color);
  7. }

上面的代码,创建car对象,并赋予属性和方法。执行代码后就可以使用对象,问题是我们经常需要重复、创建多个实例。

解决此问题的方法是:创建能够返回特定类型的对象的工厂函数。

  1. function createCar(){
  2. var oTempCar = new Object;
  3. oTempCar.color = "red";
  4. oTempCar.doors= 4;
  5. oTempCar.mpg  = 23;
  6. oTempCar.showColor= function(){
  7. alert(this.doors);
  8. }
  9. return oTempCar;
  10. }
  11. var oCar1 = createCar();
  12. var oCar2 = createCar();

执行代码,将创建2个car对象。

上面的代码仍存在问题:为每个对象创建独立的函数版本,但实际上他们的函数功能是一样的,无需独立创建。

解决方法:创建外部函数重写工厂函数。

  1. function showColor(){
  2. alert(this.color);
  3. }
  4. function createCar(){
  5. var oTempCar = new Object;
  6. oTempCar.color = "red";
  7. oTempCar.doors = 4;
  8. oTempCar.mpg = 23;
  9. oTempCar.showColor = showColor;
  10. return oTempCar;
  11. }

二、构造函数方式

在构造函数内部无需创建对象,而是使用this关键字。使用new调用构造函数。

  1. function Car(sColor, iDoors, iMpg){
  2. this.color = sColor;
  3. this.doors= iDoors;
  4. this.mpg  = iMpg;
  5. this.showColor = function(){
  6. alert(this.color);
  7. };
  8. }
  9. var oCar1 = new Car("red", 4, 23);
  10. car oCar2 = new Car("blue",3, 25);

与工厂方式相同,构造函数也存在无法共享方法的问题。解决方法仍然是使用外部函数。

三、原型方式

该方式利用了对象的prototype属性,可以把它看成创建新对象所依赖的原型。

  1. function Car(){}  //创建空构造函数类名
  2. Car.prototype.color = "red";
  3. Car.prototype.doors= 4;
  4. Car.prototype.mpg = 23;
  5. Car.prototype.showColor = function(){
  6. alert(this.color);
  7. }
  8. var oCar1 = new Car();
  9. var oCar2 = new Car();

所有的属性和方法都被直接赋予创建对象所依赖的原型prototype属性。

原型方式很好的解决了构造函数方式、工厂方式的无法共享方法问题,但却出现一个新问题:无法传递参数,初始化属性。

四、混合方式

看到三者的优缺点,唯有混合使用它们。

  1. function Car(sColor, iDoor, iMpg){
  2. this.color = sColor;
  3. this.doors=iDoors;
  4. this.mpg = iMpg;
  5. this.drivers = new Array("Mike","Sue");
  6. }
  7. Car.prototype.showColor = function(){
  8. alert(this.color);
  9. }
  10. var oCar1 = new Car("red", 4, 23);
  11. var oCar2 = new Car("blue", 3, 25);
  12. oCar1.drivers.push("Matt");
  13. alert(oCar1.drivers); //输出 "Mike,Sue,Matt"
  14. alert(oCar2.drivers);//输出  "Mike,Sue"

1、使用构造函数方式,解决了传递参数的问题。

2、使用原型方式解决了共享函数指向同一函数指针的问题。

JavaScript之工厂方式 构造函数方式 原型方式讲解的更多相关文章

  1. javascript继承之借用构造函数与原型

    javascript继承之借用构造函数与原型 在js中,关于继承只有利用构造函数和原型链两种来现实.以前所见到的种种方法与模式,只不过是变种罢了. 借用构造函数 1 2 3 4 5 6 7 8 9 1 ...

  2. Javascript面向对象——创建对象、构造函数的原型

    Javascript面向对象--创建对象.构造函数的原型 其实:JavaScript中的创建类,就是创建一个构造函数,在创建对象时用到new这个关键字, 一.创建对象 1.函数创建对象 functio ...

  3. JavaScript对象的创建之动态原型方式

    为了让定义的方式更加符合java的需求,就把定义方法的原型代码放置在Person这个构造函数中. function Person(name,age,friends){ //属性在构造函数中定义 thi ...

  4. JavaScript对象的创建之基于原型方式

    原型内存模型介绍 原型是javascript中非常特殊的一个对象,当一个函数创建之后,会随之就产生一个原型对象. 当通过这个函数的构造函数创建一个具体的对象之后,在这个具体的对象中就会有一个属性指向原 ...

  5. JavaScript中定义对象的四种方式

    最近在阅读< JavaScript 高级程序设计>,未免遗忘读过的内容,就打算以博客的形式做些读书笔记.今天介绍的是 JavaScript 中的四种定义对象的方法,除了这四种方法,还有工厂 ...

  6. 声明对象的方式/构造函数/原型/this指向

      函数的发展历程(声明函数的方式):     1.通过Object构造函数或字面量的方式创建单个对象 var obj = new Object; obj.name="新华"; o ...

  7. JavaScript提高篇之面向对象之单利模式工厂模型构造函数原型链模式

    1.单例模式 <!DOCTYPE html> <html lang="en"> <head> <meta charset="UT ...

  8. JavaScript高级特性-创建对象的九种方式

    1. 对象字面量 通过这种方式创建对象极为简单,将属性名用引号括起来,再将属性名和属性值之间以冒号分隔,各属性名值对之后用逗号隔开,最后一个属性不用逗号隔开,所有的属性名值对用大括号括起来,像这样: ...

  9. Javascript中函数的四种调用方式

    一.Javascript中函数的几个基本知识点: 1.函数的名字只是一个指向函数的指针,所以即使在不同的执行环境,即不同对象调用这个函数,这个函数指向的仍然是同一个函数. 2.函数中有两个特殊的内部属 ...

随机推荐

  1. Java实现0~100之和

    经典问题了,三个变量分别表示起始.结尾以及和,for循环从起始到结尾,和不断累积.代码如下: public class ForLoop { public static void main(String ...

  2. MapReduce shuffle阶段详解

    在Mapreduce中,Shuffle过程是Mapreduce的核心,它分布在Mapreduce的map阶段和reduce阶段,共可分为6个详细的阶段: 1).Collect阶段:将MapTask的结 ...

  3. java-testng-selenium优化

    由于项目中webui测试的需要,是用testng+selenium的方式,其中遇到过几个问题,记录下,方便以后查看 1.重复运行多次case 因为是selenium,所以有的时候需要运行多次,方法是写 ...

  4. Python学习教程(learning Python)--2.3 Python自定义函数传参函数设计

    Python里自定义子函数时,可以在调用时携带一些参数到子函数里去处理.具体用法结构如下: def func(arguments): statement statement etc. 定义子函数一定要 ...

  5. android ptl

    Gerrit android update sdk --no-uiadb logcat MyActivity:* *:S Connecting adb over Wi-Fiadb tcpip 5555 ...

  6. swift 2

    ... ..< func a(inout a)  //by ref  use &xx Parameters passed to functions are constants by de ...

  7. Linux下安装宋体以及微软雅黑字体

    最近工作用itext生成pdf在windows环境下没有出现中文乱码而在linux下出现中文乱码,打开pdf查看pdf编码,以及显示的编码,发现编码并没有对应.原因是使用的宋体和微软雅黑在linux环 ...

  8. ORACLE SQL TUNING ADVISOR 使用方法

    sql tunning advisor 使用的主要步骤: 1 建立tunning task 2 执行task 3 显示tunning 结果 4 根据建议来运行相应的调优方法  下面来按照这个顺序来实施 ...

  9. iOS7 隐藏状态栏 hide statusBar

    1.调用 [self setNeedsStatusBarAppearanceUpdate]; 2.重载以下函数 - (BOOL)prefersStatusBarHidden{ return _hide ...

  10. (转)前端构建工具gulp入门教程

    前端构建工具gulp入门教程 老婆婆 1.8k 2013年12月30日 发布 推荐 10 推荐 收藏 83 收藏,20k 浏览 本文假设你之前没有用过任何任务脚本(task runner)和命令行工具 ...