`
lovnet
  • 浏览: 6878282 次
  • 性别: Icon_minigender_1
  • 来自: 武汉
文章分类
社区版块
存档分类
最新评论

javaScript中如何定义类

阅读更多

方法源自《javaScript高级程序设计》一书


第一种方式: 工厂方法

能创建并返回特定类型的对象的工厂函数(factory function)。

functioncreateCar(sColor)...
{
varoTempCar=newObject;
oTempCar.color
=sColor;
oTempCar.showColor
=function()...
{
alert(
this.color);
}
;
returnoTempCar;
}

varoCar1=createCar();
varoCar2=createCar();

这是一个典型的简单工厂模式。
看一段函数定义在外部的方法:


在这段代码中,在函数createCar()前定义了函数showColor().

在createCar()内部,赋予对象一个已经指向已经存在的showColor()函数的指针。从功能上来讲,这样解决了重复创建对象的问题,但该函数看起来不像对象的方法。
所有这些问题引发了开发者定义的构造函数的出现。

第二种方式:构造函数方式


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

第三种方式:原型方式

调用new Car()时,原型的所有属性都被立即赋予要创建的对象,意味着所有的Car实例存放的都是指向showColor()函数的指针。从语义上看起来都属于一个对象,因此解决了前面两种方式存在的两个问题。此外使用该方法,还能用instanceof运算符检查给定变量指向的对象类型。因此,下面的代码将输出true:
alert(oCar instanceof Car); //outputs "true"
这个方式看起来很不错,遗憾的是,它并不尽如人意。
1首先这个构造函数没有参数。使用原型方式时,不能给构造函数传递参数初始化属性的值,因为car1和car2的属性都等于“red”。
2真正的问题出现在属性指向的是对象,而不是函数时。函数共享不会造成任何问题,但是对象却很少被多个实例共享的。

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


第五种方式:动态原型方式(推荐)
对于习惯使用其他语言的开发者来说,使用混合的构造函数/原型方式感觉不那么和谐。批评混合的构造函数/原型方式的人认为,在构造函数内找属性,在外部找方法的做法很不合理。所以他们设计了动态原型方式,以提供更友好的编码风格。
动态原型方法的基本想法与混合的构造函数/原型方式相同,即在构造函数内定义非函数属性,而函数属性则利用原型属性定义。唯一的区别是赋予对象方法的位置。下面是使用动态原型方法重写的Car类:

functionCar(sColor)...{
this.color=sColor;
this.drivers=newArray("Mike","Sue");

if(typeofCar._initialized=="undefined")...{
Car.prototype.showColor
=function()...{
alert(
this.color);
}

}

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

varoCar1=newCar("red");
varoCar2=newCar("blue");
分享到:
评论

相关推荐

    javascript中定义类的方法汇总

    在JavaScript中,定义类是构建面向对象程序的基本方式之一。本文主要汇总了在JavaScript中定义类的多种方法,并对每种方法进行了详细讲解和代码示例。 首先,我们介绍了工厂方式。工厂方式是最简单的创建对象的方法...

    JavaScript定义类的几种方式总结

    JavaScript定义类的几种方式包括工厂方式、构造函数和原型方式,每种方法都有其特点和适用场景,接下来我们将详细探讨。 工厂方式是最早期的面向对象编程在JavaScript中的实践之一。使用工厂方式定义类,本质上就是...

    javascript中定义类的方法详解

    在JavaScript中定义类的方法主要有以下几种方式: 1. 工厂方式: 工厂方式是一种创建对象的模式,这种模式中,定义了一个函数用于返回一个新对象,这个对象具有预设的属性和方法。这种方式的好处是不需要直接使用...

    JavaScript定义类或函数的几种方式小结

    JavaScript中定义类或函数,主要有以下几种方式: 1. 工厂方式 工厂方式是JavaScript中创建对象的一种模式,它通过一个工厂函数来封装创建对象的代码。通过工厂函数,我们可以创建多个具有相同属性和方法的对象实例...

    javaScript中定义类或对象的五种方式总结

    JavaScript 中定义类或对象的方式主要有以下五种,每种方式都有其特点和适用场景。 1. 工厂方法 工厂方法是一种创建对象的模式,它通过一个函数来创建并返回对象,而不是直接使用 new 关键字。使用工厂方法可以创建...

    JS定义类或对象

    下面我们将详细介绍如何在JavaScript中定义类或对象,并逐步展示其优势。 #### 二、定义对象的基本方法 ##### 2.1 使用函数创建对象 在JavaScript中,可以通过定义一个函数来创建对象。以下是一个简单的例子,...

    JavaScript定义类和对象的方法

    在JavaScript中定义类和对象的方法大致可以分为两类,一种是使用函数方式定义,另一种是先实例化Object类的方式定义。下面详细介绍这两种方法的实现和使用。 首先,函数方式定义类是最直观和常用的方法,它基于函数...

    JavaScript的面向对象特性浅析与范例.pdf

    定义一个类的通用格式如下:function类名(参数列表){ //类的属性的定义 //类的方法的定义 } JavaScript定义类是通过定义函数直接实现的,每个函数可以直接看成class。 3. 定义类的数据成员——属性:在定义类的...

    JavaScript中支持面向对象的基础[参照].pdf

    首先,我们来看如何在JavaScript中定义类。不同于其他一些面向对象的语言,JavaScript使用函数来表示类。例如,可以定义一个名为`class1`的类,如下: ```javascript function class1() { // 类成员的定义及构造...

    JavaScript面向对象精要(英文版)

    ES6引入了`class`语法,使得在JavaScript中定义类变得更加直观。实际上,ES6的类语法是对原型继承的一种封装,它提供了一种更加清晰的方式来组织代码。 ##### 3.1 定义类 ```javascript class Person { ...

    JavaScript中支持面向对象的基础

    首先,我们要理解如何在JavaScript中定义类。尽管JavaScript原生并不支持传统的类语法(在ES6之前),但它可以通过函数来模拟类的概念。一个函数可以作为类的构造函数,用来初始化新创建的对象。例如: ```...

    Javascript定义类(class)的三种方法详解

    本文将详细解释三种在JavaScript中定义类的方法:构造函数法、Object.create()法以及极简主义法。 1. 构造函数法 构造函数法是最常见的模拟类的方式,通过使用函数作为类的模板。构造函数通常以大写字母开头,表示...

    老生常谈javascript的面向对象思想

    在JavaScript中定义类或对象有多种方式: 第一种是基于Object对象。这种方式创建的对象是通过构造函数与Object原型链关联起来的。但是这种方式的缺点是,无法创建多个具有相同行为但不同数据的对象。 第二种是基于...

Global site tag (gtag.js) - Google Analytics