关于js的对象原型继承

Posted 夜月天

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了关于js的对象原型继承相关的知识,希望对你有一定的参考价值。

javascript中,对象的继承是通过原型去继承。

可以这样理解:js中的对象,包含的除了属性和方法,还有一个最基本的原型__proto__对象。这个原型__proto__指向谁,这个对象就继承谁。这是最容易理解对象原型继承的一种方式。

如下面的代码:

var student={
    name:zhangsan,
    age:21,
    run:function(){
        return this.name+ is running!;
    }
};

var xiaoming={
    name:xiaoming
};

xiaoming.__proto__=student;

xiaoming这个对象除了拥有自己的name属性,还继承了student对象。可以直接调用student的run方法,如:xiaoming.run();

当然,直接对对象的__proto__赋值不是一种好的方法,可以用Object.create(A)来代替。如下面的代码:

var student={
    name:zhangsan,
    age:21,
    run:function(){
        return this.name+ is running!;
    }
};

function createStudent(name){
    var stu=Object.create(student);
    stu.name=name;    return stu;
}

var xiaoming=createStudent(xiaoming);

document.write(xiaoming.__proto__ === student); //true

以上代码证明使用Object.create(A)来创建一个对象,这个对象的__proto__指向的是A对象。

这只是创建原型继承的众多方法之一。

以上是关于关于js的对象原型继承的主要内容,如果未能解决你的问题,请参考以下文章

关于对象构造函数原型原型链继承

关于JS原型原型链继承的问题

关于js中的原型问题

关于JS 的原型和原型链

js 继承与原型链

Js中的对象构造函数原型原型链及继承