Javascript中的类实现
Javascript本身并不支持面向对象,它没有访问控制符,它没有定义类的关键字class,它没有支持继承的exte
d或冒号,它也没有用来支持虚函数的virtual,不过,Javascript是一门灵活的语言,下面我们就看看没有关键字class的Javascript如何实现类定义,并创建对象。一:定义类并创建类的实例对象定义类并创建类的实例对象在Javascript中,我们用fu
ctio
来定义类,如下:
fu
ctio
Shapevarx1vary2
你或许会说,疑?这个不是定义函数吗?没错,这个是定义函数,我们定义了一个Shape函数,并对x和y进行了初始化。不过,如果你换个角度来看,这个就是定义一个Shape类,里面有两个属性x和y,初始值分别是1和2,只不过,我们定义类的关键字是fu
ctio
而不是class。然后,我们可以创建Shape类的对象aShape,如下:
varaShape
ewShape
二:定义公有属性和私有属性我们已经创建了aShape对象,但是,当我们试着访问它的属性时,会出错,如下:
aShapex1
这说明,用var定义的属性是私有的。我们需要使用this关键字来定义公有的属性
fu
ctio
Shapethisx1thisy2
这样,我们就可以访问Shape的属性了,如。
aShapex2
好,我们可以根据上面的代码总结得到:用var可以定义类的private属性,而用this能定义类的public
f属性。三:定义公有方法和私有方法在Javascript中,函数是Fu
ctio
类的实例,Fu
ctio
间接继承自Object,所以,函数也是一个对象,因此,我们可以用赋值的方法创建函数,当然,我们也可以将一个函数赋给类的一个属性变量,那么,这个属性变量就可以称为方法,因为它是一个可以执行的函数。代码如下:
fu
ctio
Shapevarx0vary1thisdrawfu
ctio
pri
t
我们在上面的代码中定义了一个draw,并把一个fu
ctio
赋给它,下面,我们就可以通过aShape调用这个函数,OOP中称为公有方法,如:
aShapedraw
如果用var定义,那么这个draw就变成私有的了,OOP中称为私有方法,如
fu
ctio
Shapevarx0vary1vardrawfu
ctio
pri
t
这样就不能使用aShapedraw调用这个函数了。
三:构造函数Javascript并不支持OOP,当然也就没有构造函数了,不过,我们可以自己模拟一个构造函数,让对象被创建时自动调用,代码如下:
fu
ctio
Shapevari
itfu
ctio
f构造函数代码i
it
在Shape的最后,我们人为的调用了i
it函数,那么,在创建了一个Shape对象是,i
it总会被自动调用,可以模拟我们的构造函数了。
四:带参数的构造函数如何让构造函数带参数呢?其实很简单,r