call()和apply()

JavaScript方法call与apply用法详解
本文深入探讨了JavaScript中call和apply方法的使用,包括它们的语法、定义、说明以及实例应用,旨在帮助开发者更好地理解并运用这两个方法解决实际问题。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<meta http-equiv="content-type" content="text/html";charset="gbk"/ >
<script type="text/javascript" >
 /*function Animal(){
   this.name="animal";
   this.showName=function(){
   alert(this.name);
   }
 }
 function Cat(){
   this.name="cat";
 }

 var animal=new Animal();
 var cat=new Cat();
    animal.showName.call(cat);*/                             cat

    function myFun(a,b,c){
   this.a = a;
   this.b = b;
   this.c = c;
 }
     var myObject = new Object();
  alert(myObject.a);                                                             undefined
  /*myFun.call(myObject,23,45,67);*/                                             23
  myFun.apply(myObject,[23,45,67]);                                              23
  alert(myObject.a);
</script>
</head>
<body>
   
</body>
</html>

 

 

call方法:
语法:call([thisObj[,arg1[, arg2[,   [,.argN]]]]])
定义:调用一个对象的一个方法,以另一个对象替换当前对象。
说明:
call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。
如果没有提供 thisObj 参数,那么 Global 对象被用作 thisObj。

apply方法:

语法:apply([thisObj[,argArray]])
定义:应用某一对象的一个方法,用另一个对象替换当前对象。
说明:
如果 argArray 不是一个有效的数组或者不是 arguments 对象,那么将导致一个 TypeError。
如果没有提供 argArray 和 thisObj 任何一个参数,那么 Global 对象将被用作 thisObj, 并且无法被传递任何参数。

转载于:https://www.cnblogs.com/lowbrid/p/3558339.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值