JavaScript之面向对象_动力节点Java学院整理
javascript的所有数据都可以看成对象,那是不是我们已经在使用面向对象编程了呢?
当然不是。如果我们只使用number、array、string以及基本的{...}定义的对象,还无法发挥出面向对象编程的威力。
javascript的面向对象编程和大多数其他语言如java、c#的面向对象编程都不太一样。如果你熟悉java或c#,很好,你一定明白面向对象的两个基本概念:
1.类:类是对象的类型模板,例如,定义student类来表示学生,类本身是一种类型,student表示学生类型,但不表示任何具体的某个学生;
2.实例:实例是根据类创建的对象,例如,根据student类可以创建出xiaoming、xiaohong、xiaojun等多个实例,每个实例表示一个具体的学生,他们全都属于student类型。
所以,类和实例是大多数面向对象编程语言的基本概念。
不过,在javascript中,这个概念需要改一改。javascript不区分类和实例的概念,而是通过原型(prototype)来实现面向对象编程。
原型是指当我们想要创建xiaoming这个具体的学生时,我们并没有一个student类型可用。那怎么办?恰好有这么一个现成的对象:
var robot = { name: 'robot', height: 1.6, run: function () { console.log(this.name + ' is running...'); } };
我们看这个robot对象有名字,有身高,还会跑,有点像小明,干脆就根据它来“创建”小明得了!
于是我们把它改名为student,然后创建出xiaoming:
var student = { name: 'robot', height: 1.2, run: function () { console.log(this.name + ' is running...'); } }; var xiaoming = { name: '小明' }; xiaoming.__proto__ = student;
注意最后一行代码把xiaoming的原型指向了对象student,看上去xiaoming仿佛是从student继承下来的:
xiaoming.name; // '小明' xiaoming.run(); // 小明 is running...
xiaoming有自己的name属性,但并没有定义run()方法。不过,由于小明是从student继承而来,只要student有run()方法,xiaoming也可以调用:
javascript的原型链和java的class区别就在,它没有“class”的概念,所有对象都是实例,所谓继承关系不过是把一个对象的原型指向另一个对象而已。
如果你把xiaoming的原型指向其他对象:
var bird = { fly: function () { console.log(this.name + ' is flying...'); } }; xiaoming.__proto__ = bird;
现在xiaoming已经无法run()了,他已经变成了一只鸟:
xiaoming.fly(); // 小明 is flying...
在javascrip代码运行时期,你可以把xiaoming从student变成bird,或者变成任何对象。
请注意,上述代码仅用于演示目的。在编写javascript代码时,不要直接用obj.__proto__去改变一个对象的原型,并且,低版本的ie也无法使用__proto__。object.create()方法可以传入一个原型对象,并创建一个基于该原型的新对象,但是新对象什么属性都没有,因此,我们可以编写一个函数来创建xiaoming:
// 原型对象: var student = { name: 'robot', height: 1.2, run: function () { console.log(this.name + ' is running...'); } }; function createstudent(name) { // 基于student原型创建一个新对象: var s = object.create(student); // 初始化新对象: s.name = name; return s; } var xiaoming = createstudent('小明'); xiaoming.run(); // 小明 is running... xiaoming.__proto__ === student; // true
上一篇: JavaScript算法教程之sku(库存量单位)详解
下一篇: 二分法试题
推荐阅读
-
Java Properties简介_动力节点Java学院整理
-
Java8新特性之JavaFX 8_动力节点Java学院整理
-
Java concurrency之锁_动力节点Java学院整理
-
Java8新特性之Base64详解_动力节点Java学院整理
-
Java8新特性之泛型的目标类型推断_动力节点Java学院整理
-
Java8新特性之StampedLock_动力节点Java学院整理
-
Java8新特性之lambda的作用_动力节点Java学院整理
-
Java Socket编程简介_动力节点Java学院整理
-
Java 异步编程实践_动力节点Java学院整理
-
Java数据库连接池之proxool_动力节点Java学院整理