当然不是。如果我们只使用、Arraystring以及基本的{...}定义的对象,还无法发挥出面向对象编程的威力。

    JavaScript的面向对象编程和大多数其他语言如Java、C#的面向对象编程都不太一样。如果你熟悉Java或C#,很好,你一定明白面向对象的两个基本概念:

    1. 类:类是对象的类型模板,例如,定义Student类来表示学生,类本身是一种类型,Student表示学生类型,但不表示任何具体的某个学生;

    2. 实例:实例是根据类创建的对象,例如,根据Student类可以创建出xiaomingxiaohongxiaojun等多个实例,每个实例表示一个具体的学生,他们全都属于Student类型。

    所以,类和实例是大多数面向对象编程语言的基本概念。

    原型是指当我们想要创建xiaoming这个具体的学生时,我们并没有一个Student类型可用。那怎么办?恰好有这么一个现成的对象:

    我们看这个robot对象有名字,有身高,还会跑,有点像小明,干脆就根据它来“创建”小明得了!

    于是我们把它改名为Student,然后创建出xiaoming

    1. var Student = {
    2. name: 'Robot',
    3. height: 1.2,
    4. run: function () {
    5. console.log(this.name + ' is running...');
    6. }
    7. };
    8. var xiaoming = {
    9. xiaoming.__proto__ = Student;

    注意最后一行代码把xiaoming的原型指向了对象Student,看上去xiaoming仿佛是从Student继承下来的:

    xiaoming有自己的name属性,但并没有定义run()方法。不过,由于小明是从Student继承而来,只要Studentrun()方法,xiaoming也可以调用:

    JavaScript的原型链和Java的Class区别就在,它没有“Class”的概念,所有对象都是实例,所谓继承关系不过是把一个对象的原型指向另一个对象而已。

    如果你把xiaoming的原型指向其他对象:

    1. var Bird = {
    2. fly: function () {
    3. console.log(this.name + ' is flying...');
    4. }
    5. };
    6. xiaoming.__proto__ = Bird;

    现在xiaoming已经无法run()了,他已经变成了一只鸟:

    在JavaScrip代码运行时期,你可以把从Student变成Bird,或者变成任何对象。

    请注意,上述代码仅用于演示目的。在编写JavaScript代码时,不要直接用obj.__proto__去改变一个对象的原型,并且,低版本的IE也无法使用__proto__Object.create()方法可以传入一个原型对象,并创建一个基于该原型的新对象,但是新对象什么属性都没有,因此,我们可以编写一个函数来创建xiaoming

    1. // 原型对象:
    2. var Student = {
    3. name: 'Robot',
    4. height: 1.2,
    5. console.log(this.name + ' is running...');
    6. }
    7. };
    8. function createStudent(name) {
    9. // 基于Student原型创建一个新对象:
    10. var s = Object.create(Student);
    11. // 初始化新对象:
    12. s.name = name;
    13. return s;
    14. }
    15. var xiaoming = createStudent('小明');
    16. xiaoming.__proto__ === Student; // true

    面向对象编程 - 图1