您好,欢迎访问一九零五行业门户网

实现JavaScript中继承的三种方式_js面向对象

一、原型链继承
在原型链继承方面,javascript与java、c#等语言类似,仅允许单父类继承。prototype继承的基本方式如下:
复制代码 代码如下:
function parent(){}
function child(){}
child.prototype = new parent();
通过对象child的prototype属性指向父对象parent的实例,使child对象实例能通过原型链访问到父对象构造所定义的属性、方法等。
构造通过原型链链接了父级对象,是否就意味着完成了对象的继承了呢?答案是否定的。如:
复制代码 代码如下:
function parent(){}
function child(){}
child.prototype = new parent();
var child = new child();
alert(child.constructor);//function parent(){}
alert(child instanceof child);//true
尽管child依然可以作为child的实例使用,但此时已经丢失了实例child原有的对象构造信息。弥补该缺陷的方法如下:
复制代码 代码如下:
function parent(){}
function child(){}
child.prototype = new parent();
child.prototype.constructor = child;
var child = new child();
alert(child.constructor);//function parent(){}
alert(child instanceof child);//true
如上代码片段“child.prototype.constructor = child”所示,通过显示地指定对象构造child的原型,强制所有的child对象实例的构造都为child。
二、使用apply、call方法
由于javascript内置的function对象的apply、call方法改变对象构造中“this”的上下文环境,使特定的对象实例具有对象构造中所定义的属性、方法。
使用apply、call继承,在实际开发中操作html页面上的dom对象时尤为常用。如:
复制代码 代码如下:
apply,call继承
通过apply或call定义的ext方法,使ext方法内部的this上下文表示为dom对象“apply,call继承
”。
值得注意的是,当使用apply、call时,会直接执行对象构造所定义的代码段,如:
复制代码 代码如下:
三、对象实例间的继承
javascript对象的多态性,允许实例动态地添加属性、方法。该特性造就了javascript中的另一种继承手法——对象实例间的继承。如:
复制代码 代码如下:
var person = {name:nathena,age:26};
var nathena = {sex:male};
(function inlineextends(so,po)
{
for (var i in po)
{
if (so[i])//如果so也具有这个成员
continue;
so[i] = po[i];
}
})(nathena,person);
alert(nathena.name);//返回nathana
如以上代码所示,在对象的实例间继承中,父对象persong定义了“人”所具有的共同属性name、age,子对象nathena定义了自己的私有属性“sex”。函数inlineextends的功能是,为子对象nathena复制父对象person中定义的“人”所具有的共同属性。
其中特别需要注意的语句是“if (so[i])”,此句确保了子对象原有的成员不被父对象中同名的成员所覆盖,而违背面向对象中父子对象之间继承的原则——子对象可以覆盖、重载父对象的属性或方法,父对象仅能对子对象隐藏自己的属性或方法。
其它类似信息

推荐信息