js中的面向对象、继承、函数重写

通过示例讲解 一下,先看一个示例

示例demo:

<script>

//创建一个父函数(父类)

var Mammal = function (name) {

this.name = name;

}

/*

给父函数的原型添加相应的方法。

注意: 函数原型中方法,以该函数为构造函数创建的所有对象均可访问。

即 : var mmm = new Mammal(); mmm可以访问 Mammal 函数中所有的方法

*/

Mammal.prototype.get_name = function () {

return this.name;

}

Mammal.prototype.says = function () {

return this.saying || " ";

}

/*

用new 调用父函数,会返回一个 用objec创建的对象,存储在变量 myMammal中

*/

var myMammal = new Mammal("herb the mammal");

console.log(myMammal);



/*

创建子函数(子类。要继承父类的函数)



*/

var Cat = function (name) {

this.name = name;

this.saying = "meow";

}

/*

用父类返回的对象替换 子类 的原型prototype。(父类返回的对象可以访问父类所有的方法)

因为用子类 Cat函数 new 的对象可以访问 cat 原型中所有的方法,而 子函数的原型又指向 父函数的对象, 父函数的对象可以访问父函数的方法。

即: 子函数的原型 指向了 父函数的 原型,这样,子函数 new 的对象就可以 访问 父类中的方法了。这样就实现了继承

*/

Cat.prototype = myMammal;

/*

通过 给子函数原型增加新的方法,来 增加 子类的功能。(即类的拓展)

*/

Cat.prototype.purr = function (n) {

var i,s = '';

for(var i = 0;i < n;i++){

if(s){

s += '-';

}

s += 'r';

}

return s;

}

/*

因为父函数中也有 get_name方法,给子函数的原型中增加 同名的 方法,这样 对象访问的时候 回 访问到 子函数 的get_name

即: 成员方法的重写

*/

Cat.prototype.get_name = function () {

return this.says() + ' ' + this.name + " " + this.says();

}



var myCat = new Cat("lihongwei");

console.log(myCat);

</script>

 

 

 

运行结果:

我们看到 父函数 Mammal 和 子函数 Cat 用new调用时,分别产生的对象的结构。

子函数 的第一层__proto__是自己原型中方法 。第二层 的 __proto__中的方法是继承自父函数 Mammal函数原型中的方法。

这就是 继承在  js 中的实现。

 

结论验证:

 

 

// 子函数的 原型 和 父函数的原型进行比较 ,

console.log(myCat.prototype === myMammal.prototype) // true

 

在一次说明了 子函数 原型  是指向 父函数的原型,并可以i访问其中的方法。这就是  js中的继承。

 

js中子函数的拓展


/*

通过 给子函数原型增加新的方法,来 增加 子类的功能。(即类的拓展)

*/

Cat.prototype.purr = function (n) {

var i,s = '';

for(var i = 0;i < n;i++){

if(s){

s += '-';

}

s += 'r';

}

return s;

}



js中子函数 对父函数 方法的重写:



/*

因为父函数中也有 get_name方法,给子函数的原型中增加 同名的 方法,这样 对象访问的时候 回 访问到 子函数 的get_name

即: 成员方法的重写

*/

Cat.prototype.get_name = function () {

return this.says() + ' ' + this.name + " " + this.says();

}



 

ps: 谢谢观看,请记得点赞。点赞的人是最帅的,和我一个级别的。

 

 

 

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

ITzhongzi

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值