js中的call和apply

本文详细解析了JavaScript中call和apply方法的使用,通过具体示例解释了这两个方法如何改变函数内部的this指向,以及它们在实现继承和参数传递方面的区别。了解这些将帮助开发者更灵活地使用JavaScript。

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

第一节:一个简单的例子
复制代码
     function add(a,b){
         console.log(a+b);
     }

     function sub(a,b){
         console.log(a-b); } add.call(sub,3,2); //5
复制代码

  总结:以上代码 定义两个方法,而最后一句话,不妨理解为 sub对象 调用了 add对象 的方法,并把参数也带入方法里。

 

 第二节:深入理解 call 和 apply

  call 和 apply的定义说明:call和apply 是函数的非继承方法,在某个特定作用范围内调用某个函数,设置函数体内this对象的值,

复制代码
     function NJie(){
         this.name = "Njie",
         this.sayName = function(){ console.log(this.name); } } function KK(){ this.name ="KK"; } var n = new NJie(); var k = new KK(); n.sayName(); //NJie n.sayName.call(k); //KK
复制代码

  总结:比如说:k 对象没有 sayName 的函数,而 n 有这个函数,那 k 就通过call 来借 n的 sayName使用,当然也要把在 k 中的值带入到方法里。

第三节:call 和 apply 的 区别

  说明:call 和 apply 的区别,在于两个传入的参数的方式不一样

  

复制代码
    // 父类
     function Person(name,age){
         this.name = name; this.age = age; } //子类 学生 function Student(name,age,grade){ Person.apply(this,arguments); //子类继承了父类 // Person.call(this,name,age); //当然,也可以使用 call的方法 this.grade = grade; } //创建一个学生的实例 var s1 = new Student("倪杰","23","北京大学成人班,一年级"); console.log("您好,",s1.name,"您今年",s1.age,"岁,就读于",s1.grade,",实在太棒了");
复制代码

  总结:

    以上的例子有两个要点:

      1,是可以使用 call的方法来做 js 的继承处理;

      2,call 和 apply 的区别主要是在于后面的传入参数方式不同,call传参数要把参数一一列出来,而apply则可以使用 arguments 这个属性直接带过去.

转载于:https://www.cnblogs.com/zynbg/p/4017214.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值