原型/原型链(三)(含call与apply方法的介绍)

本文深入探讨JavaScript中原型与父类的关系,解释this关键字的作用,以及如何使用Object.create()方法和函数重写来实现更灵活的继承机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一般来说原型与父类的增删改查是一致的。
但是有一个特例。
若父亲祖先开辟了一个方法空间,子类去调用这个方法空间的时候会获得这个方法空间的使用权,就可以进行正常的增删改查。

this的理解有一句简单粗暴的话:谁调用这个方法,this就指向谁。这在80%的情况都适用.

关于父类祖先,还有更加好的一种方法。
在这里插入图片描述
就是Object.create()方法。

上一次我说了所有的原型都指向最终原型,其实是不太严谨的说法。在这里就可以通过是同这个方法在里面存放null值,使得他本来指向最终原型的指针改为空指针。

以下去介绍函数重写的方法

在这里插入图片描述
只需要在想上寻找需要函数的路上再定义一个父类去重写方法,即可以实现函数重写。

函数的执行其实真实面目被省略了。
在这里插入图片描述
如图,执行一个函数其实是执行test.call();

call()函数内是可以放参数的。
如下图的使用Call函数,会使得创建的函数里面的this对象全部变更为obj对象。
若是还想传参数怎么办?
没关系,直接逗号往下接着写就可以了。
此时obj也拥有了对象的属性。(相当于借用别人的函数 为自己赋予属性)
在这里插入图片描述

以下是call()函数的基础运用

在这里插入图片描述
这个this将是被方法内的this给替换掉。

这是call和apply之间的区别。
1.apply与call拼写不同
2.apply第二个参数为数组,且只能有一个数组。(传参列表不同)

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值