`

JS 创建对象的几种方式

阅读更多
<script type="text/javascript">


/* 创建对象的几种方式: */

// 1. 工厂方法:能创建并返回特定类型对象的工厂函数(factory function).
function createCar(sColor){
    var car = new Object();   // 或者 var car = new Object ;
    // 对象属性
    car.color = sColor ;      
    // 对象方法
    car.showColor = function (){   
        alert(123);
    } ;    // 记住,这里一定要用 ; 表示结束
    
    return car;        // 这里是 return car ; 而不是 return this.car ; 因为 this.car 为 undefined
}
/* 
  调用此函数时,将创建对象,并赋予它所有必要的属性,使用此方法创建 car 对象的两个版本,
  ( oCar1 和 oCar2 ) ,他们的属性完全一样。
  使用此方法存在的问题:
  1. 语义上看起来不像使用带有构造函数的 new 运算那么正规.
  2. 使用这种方式必须创建对象的方法。每次调用 createCar(),都要创建 showColor(),意味着每一个对象
  都有自己的 showColor 版本,事实上,每一个对象都共享了是同一个函数.
  有些开发者在工厂函数外定义对象的方法,然后通过属性指向该方法。从而避免这个问题:
*/
function createCar2(sColor){
    var car = new Object();
    car.color = sColor ;
    car.showColor = showColor ;

    return car ;
}

function showColor(){
    alert(this.color);
}

var oCar1 = createCar('red');
var oCar2 = createCar('yellow');

var oCar3 = createCar2('blue');
var oCar4 = createCar2('black');

/*
    注意这两个对象(oCar3 和 oCar4 ) 调用showColor 属性的方式,虽然美其名曰是“属性”,其实还是方法!!!
    所以是 oCar3.showColor(); 而不是 oCar3.showColor ;
*/

oCar3.showColor();
oCar4.showColor();

/*
  在这段重写的代码中,在函数 createCar2() 前定义了函数showColor(), 在 createCar2() 内部,赋予对象一个已经
  指向已经存在的 showColor() 函数的指针,从功能上讲,这样解决了重复创建对象的问题,但该函数看起来不像对象
  的方法。

  所有这些问题引起了开发者的定义构造函数的出现
*/

// 2. 构造函数方式

function Car(sColor){
    this.color = sColor;
    this.showColor = function(){
        alert(this.color);
    };
}

var car1 = new Car('red');
car1.showColor();

/*
  你可能已经注意到第一个的差别了,在构造函数内部无创建对象,而是使用 this 关键字,使用 new 
  运算符调用构造函数,在执行第一行代码前先创建一个对象,只有用 this 才能访问该对象。然后可以
  直接赋予 this 属性,默认情况下是构造函数的返回值,(不必明确使用 return 运算符)。
  这种方式在管理函数方面与工厂方法一样都存在相同的问题.
 */

// 3. 原型方式
function PCar(){
}

PCar.prototype.color = "blue";
var pcar1 = new PCar();

/*
  调用 new Car()时,原型的所有属性都被立即赋予要创建的对象,意味着所有的 PCar 实例存放的是指向
  showColor() 函数的指针,从语义看起来都属于一个对象,因此解决了前面两种方式存在的问题。此外使用
  该方法,还能使用 instanceof 运算符检查给定变量指向的对象类型。因此下面的代码将输出 true:
*/
alert(pcar1 instanceof PCar);  // output "true"

/*
  这个方法看起来不错,遗憾的是,它并不尽人意。
  1. 首先这个构造函数没有参数。使用原型方式时,不能给构造函数传递参数初始化属性值,因为 pcar1 和
      pcar2 的属性都等于 "blue"
  2. 真正的问题出现在属性指向的对象,而不是函数时,函数共享不会造成任何问题,但是对象却是很少被多个
      实例共享的。
 */


 // 4. 混合的构造函数/原型方式(推荐)
/*
  联合使用构造函数和原型方式,就可像使用其他程序设计语言一样创建对象,这种概念非常简单,即用构造函数
  定义对象的所有非函数属性,用原型方式定义对象的函数属性(方法)。
 */

function hCar(sColor){
    this.color = sColor;    
    this.drivers = new Array('Mike','Sue');
}

hCar.prototype.showColor = function(){
    alert(this.color);
}

var hcar1 = new hCar('y color');
var hcar2 = new hCar('r color');

hcar1.drivers.push('Matt');

alert(hcar1.drivers);  // output "Mike,Sue,Matt"
alert(hcar2.drivers);  // output "Mike,Sue"

// 5. 动态原型方式 (推荐)
/*
  对于习惯使用其他开发语言的开发者来说,使用混合构造函数/原型方式感觉不那么和谐。批评构造函数/原型方式的人
  认为,在构造函数内找属性,在外部找方法的做法不合理。所以他们设计了动态原型方式,以供更友好的编码风格。

  动态原型方式的基本想法与混合构造函数/原型方式 相同,即在构造函数内定义非函数的属性,而函数的属性则利用
  原型属性定义。唯一的区别是赋予对象方法的位置。下面是使用动态原型方法重写的 Car 类:
*/

function DCar(sColor){
    this.color = sColor;
    this.drivers = new Array('Mike','Sue');
    
    if(typeof DCar._initialized == 'undefined'){
        
        DCar.prototype.showColor = function(){
            alert(this.color);
        }
    }

    DCar._initialized = true;
}


var dcar1 = new DCar('y dcar');
var dcar2 = new DCar('b dcar');

dcar1.showColor();
dcar2.showColor();



alert(DCar._initialized);    // output "true"
alert(dcar1._initialized);  // output "undefined"

</script>
分享到:
评论

相关推荐

    javascript创建对象的方式(二)

    这篇博客“javascript创建对象的方式(二)”可能详细介绍了在JavaScript中除了最基础的字面量语法之外的其他创建对象的方法。这里我们将深入探讨几种常见的创建对象的方式。 1. **构造函数**: JavaScript中的...

    JavaScript学习之二 — JavaScript创建对象的8种方式

    JavaScript是Web开发中不可或缺的一部分,尤其在前端领域更是发挥着...以上就是JavaScript创建对象的8种常见方式,每种方式都有其适用场景和优缺点。理解并熟练运用这些技巧,可以帮助你在JavaScript开发中游刃有余。

    js创建对象几种方式的优缺点对比

    本文将详细对比JavaScript创建对象的五种常见方式:工厂模式、构造函数、原型方法、构造函数与原型方法的组合以及动态原型方法,分析它们的优缺点。 1. 工厂模式: 工厂模式是一种创建对象的方式,通过函数来创建...

    js创建对象的几种方式及JSON.docx

    js创建对象的几种方式及JSON.docx

    js创建对象的几种方式及JSON.pdf

    js创建对象的几种方式及JSON.pdf

    js面向对象之常见创建对象的几种方式(工厂模式、构造函数模式、原型模式).docx

    ### JavaScript面向对象之常见创建对象的方式 #### 引言 JavaScript 的灵活性体现在其创建对象的多种方式上。本文将详细介绍三种常见的对象创建方法:工厂模式、构造函数模式以及原型模式,并探讨它们各自的优缺点...

    js创建对象的几种方式

    1.new Object() 2.字面量创建对象 构造函数创建对象 工厂模式

    【JavaScript源代码】详解js创建对象的几种方式和对象方法.docx

    本文将深入探讨JavaScript中创建对象的几种常见方式以及对象方法。 首先,我们来看“工厂模式”。工厂模式是一种创建对象的抽象方式,通过一个函数来返回一个新的对象。例如: ```javascript function getObj(name...

    javascript创建对象的方式(一)

    这篇博文主要探讨了JavaScript创建对象的几种常见方式,这对于理解和掌握JavaScript面向对象编程至关重要。在实际开发中,了解并灵活运用这些方法能够提高代码的可读性和可维护性。下面,我们将详细讲解标题中提到的...

    JS 创建对象(常见的几种方法)

    JavaScript作为一门面向对象的脚本语言,其创建对象的方式多种多样,每种方式都有其独特的特点和适用场景。下面我们逐一分析给定文件中所提到的几种创建对象的方法。 首先是使用构造函数模式创建对象。构造函数是...

    在js中创建类和对象

    本文将详细介绍几种常见的创建对象的方法,包括它们的特点和优缺点。 5.1 工厂方法 工厂方法是一种创建对象的模式,通过一个函数来创建具有特定属性和行为的对象。在JavaScript中,我们可以定义一个函数,如`...

    JS创建对象的几中方式

    在JavaScript中,创建对象有多种方法,每种方式都有其优缺点。以下是对这些方法的详细解释: 1. **工厂方式**: 工厂函数是通过一个函数来创建对象,它可以根据需要设置属性和方法。然而,这种方法的缺点是每个...

    javascript如何创建对象

    JavaScript创建对象的方法主要有以下几种: 一、直接创建 直接创建是通过new Object()来创建一个新的空对象,然后逐步给这个对象添加属性和方法。例如,创建一个名为person1的对象,并添加name、gender属性,以及一...

    js面向对象之常见创建对象的几种方式(工厂模式、构造函数模式、原型模式)

    在上篇文章给大家介绍了javascript面向对象基础,本...因此为了解决这个问题,人们开始使用以下几种方式来常见对象。 工厂模式 该模式抽象了创建对象的具体过程,用函数来以特定接口创建对象的细节 function cPerson

    js创建对象的几种常用方式小结(推荐)

    本文将详细介绍JavaScript创建对象的几种常见方式,以及它们的优缺点。 首先,我们来看**工厂模式**。这种方式通过一个函数来创建对象,它能创建具有相同属性和方法的对象。然而,工厂模式的缺点在于它没有明显的...

    JS对象创建的几种方式整理

    最近一直在看JS高级程序设计这本书,有空来梳理一下几种创建对象的方式。话不多说,直接步入正题。 第一种:Object构造函数创建 var Person = new Object(); Person.name = 'Nike'; Person.age = 29; 这行代码创建...

    JS 5种遍历对象的方式

    感觉事情并不这么简单,于是我仔细看了一下这几种遍历对象的方法的区别 for in for in 循环是最基础的遍历对象的方式,它还会得到对象原型链上的属性 // 创建一个对象并指定其原型,bar 为原型上的属性 const obj =...

    javascript中创建对象的几种方法总结

    在JavaScript中,有几种常见的创建对象的方法,这里我们将详细探讨这些方法。 1. **对象字面量**:这是最简单且直观的创建对象的方式。通过大括号 `{}` 创建一个空对象,然后通过点`.`或方括号`[]`来添加属性和方法...

Global site tag (gtag.js) - Google Analytics