关于JavaScript中的类Class详细介绍
在JavaScript中,可以使用类(Class)来实现面向对象编程(Object Oriented Programming)。不过,JavaScript中的类与Java中的有所不同,其相应的定义和使用也不一样。
JavaScript中类的定义
在JavaScript中,所有从同一个原型对象(prototype)处衍生出来的对象组成了一个类;也就是说,JavaScript中的类是一个对象集合的概念,如果两个对象它们的prototype相同,那么它们就属于同一个类;JavaScript中的类甚至都不需要类名。以下面的代码为例:
复制代码 代码如下:
var p = {x:42};
var a = te(p);
var b = te(p);
(a === b);//false
(rototypeOf(a) === rototypeOf(b));//true
在上述例子中,对象a和b拥有相同的原型对象(prototype) p,因此a和b属于同一个类(虽然这个类都没有类名),它们从原型对象p处继承了值为42的属性x。
从这个例子中可以看到,原型对象的作用就相当于模板,可以由之衍生/创建出多个对象,其地位与Java语言中的类代码(Class code)相同,是JavaScript中类定义的核心。以下这个例子中的原型对象就呈现出更像类代码的样子:
复制代码 代码如下:
var p = {
INCREMENT_BY : 1,
increment : function(x){
return x + EMENT_BY;
}
}
var a = te(p);
var b = te(p);
(ement(7));//8
(ement(9));//10
上述例子中,原型对象p定义了一个值为1的property (INCREMENT_BY)和一个名为increment的函数;对象a和b从p这个模板处获取了INCREMENT_BY和increment函数。当调用对象a或b的increment函数时,JavaScript会试图获取a或b的INCREMENT_BY值(EMENT_BY);由于INCREMENT_BY是从p中获取的,因此其值都是1 — 从模板中获取的,值都相同的变量,类似于Java中的静态类变量(static variable),因此上面的例子中对INCREMENT_BY变量命名时使用了全大写字符。
在上面的例子中,所有从模板p处创建出来的对象(属于同一个类的这些对象),其属性和行为都是一模一样的。但实际上对于同一个类的不同对象,它们除了拥有类所定义的属性/行为以外,往往具有一些自身所特有的属性与行为。因此,如果需要将prototype这个模板当作类来使用的话,就必须对每一个从中衍生出来的对象进行一定的定制:
复制代码 代码如下:
var p = {
INCREMENT_BY : 1,
increment : function(x){
return x + EMENT_BY + om_increment_by;
}
}
var a = te(p);
var b = te(p);
om_increment_by = 0;
om_increment_by = 1;
(ement(7));//8
(ement(9));//11
在这个例子中,从模板p处创建出来的对象a和b拥有一个彼此间值不一定相等的变量custom_increment_by,而它们的increment()函数这个行为的最终结果则与custom_increment_by的值相关。一般来说,对新建对象进行定制化的工作往往放在统一的函数中进行:
复制代码 代码如下:
var p = {
INCREMENT_BY : 1,
increment : function(x){
return x + EMENT_BY + om_increment_by;
}
}
function getIncrementalClassObject(customIncrementByValue){
var incrementalObj = te(p);
om_increment_by = customIncrementByValue;
return incrementalObj;
}
var a = getIncrementalClassObject(0);
var b = getIncrementalClassObject(1);
(ement(7));//8
(ement(9));//11
如此,便通过原型对象p和getIncrementalClassObject()函数完成了一个类的定义:可以通过调用getIncrementalClassObject()函数来获取原型对象都是p的对象,而在调用getIncrementalClassObject()函数过程中可以对这些新建对象进行一定的定制化。值得注意的是,此时这个已经定义了的类还没有类名,为了方便描述,姑且称之为Incremental。
回顾getIncrementalClassObject()函数中所做的工作,可以看到从Incremental这个类中创建新的对象所经历的过程如下:
1.创建一个空对象,并将其原型对象定义为p。
2.根据不同的参数值,对这个新建的空对象进行定制。
3.返回已经定制完成的新对象。
在JavaScript中,可以通过使用Constructor(构造函数)来快速地完成类的定义以及新对象的创建。
JavaScript中的Constructor(构造函数)
从上述Incremental类这个例子中可以看到,定义新的类需要两部分代码:创建原型对象作为模板、创建自定义函数对新对象进行初始化;而从类中创建新的对象则经历了三个过程:指定新对象的.原型对象、定制/初始化新对象、返回这个新对象。在JavaScript中,这一切都可以通过Constructor(构造函数)来完成。
JavaScript中的Constructor是一个函数(function),承担对新对象进行初始化的职责;而这个Constructor函数的prototype则作为模板用于创建新对象。仍以上述Incremental类为例,用Constructor来重写代码后是这样的:
复制代码 代码如下:
function Incremental(customIncrementByValue){
om_increment_by = customIncrementByValue;
}
otype = {
INCREMENT_BY : 1,
increment : function(x){
return x + EMENT_BY + om_increment_by;
}
}
var a = new Incremental(0);
var b = new Incremental(1);
(ement(7));//8
(ement(9));//11
通过new关键词,使用Constructor函数来创建新对象这一过程,其实际上经历了以下几个阶段:
创建一个新的空对象。
1.将这个对象的原型对象指向constructor函数的prototype属性。
2.将这个对象作为this参数,执行constructor函数。
3.这与之前的getIncrementalClassObject()函数中所做的工作是一样的。
类名
在使用Constructor创建对象时,相应的对象也就有了“类名”,这可以从instanceof操作符的结果上得到验证:
复制代码 代码如下:
(a instanceof Incremental);//true
(b instanceof Incremental);//true
不过,instanceof操作符并不判断对象是否由Incremental这一构造函数所创建,instanceof操作符只判断对象的原型对象是否为otype。当存在两个prototype一样的构造函数时,instanceof操作符将统一返回true,而不会区分用于创建对象的构造函数到底是哪个。
复制代码 代码如下:
function Incremental2(customIncrementByValue){
om_increment_by = customIncrementByValue + 3;
}
otype = otype;
(a instanceof Incremental2);//true
-
平面广告中使用图形创意的作用
提起平面广告相信许多小伙伴们都不会感到陌生吧,在于一些产品来说,打广告太常见了,可以起到很好的宣传作用,以下是小编给大家带来的平面广告中使用图形创意的作用,希望对大家有帮助。视觉设计又可以称之为图形设计,是VisualCommunicationDesign的中文翻译。有时在西...
-
移动硬盘突然识别不了
导语:移动硬盘顾名思义是以硬盘为存储介质,计算机之间交换大容量数据,强调便携性的存储产品,系统不能识别移动硬盘怎么办呢?在正常情况下,移动硬盘同主机相连后系统即可将它认成“移动存储设备”,并自动在“我的电脑”中添加盘符。如果系统将移动硬盘认成“未知的USB...
-
Excel中批量删除超链接的方法
Excel中某列单元格均含有超链接,数量巨大,因此只能考虑采用批量删除法,下面跟小编学习一下批量删除超链接的方法。一、宏代码去除法打开该Excel文件,切换到视图选项卡,点击宏→录制宏,出现录制新宏窗口,在宏名定义一个名称为:RemoveHyperlinks(图2),点击确定退出;再...
-
SEO常见术语
链接场(LinkFarm)在SEO术语中,链接场是指一个充满链接的页面,这些链接其实没有实际作用,它们只作为链接存在,而没有任何实际的上下文。那些采用运用黑帽SEO方法的人利用链接场,在一个页面中增加大量链接,希望能通过这种方式使Google误认为这个页面很有链接的价值。交...