JavaScript中的apply()方法和call()方法使用介绍

  1. 每个函数都包含两个非继承而来的方法:apply()和call()。 
  2. 他们的用途相同,都是在特定的作用域中调用函数。 
  3. 接收参数方面不同,apply()接收两个参数,一个是函数运行的作用域(this),另一个是参数数组。call()方法第一个参数与apply()方法相同,但传递给函数的参数必须列举出来。 

例1:

window.firstName = "diz"; 
window.lastName = "song"; 
var myObject = { firstName: "my", lastName: "Object" }; 
function HelloName() { 
  console.log("Hello " + this.firstName + " " + this.lastName, " glad to meet you!"); 
} 
HelloName.call(window); //huo .call(this); 
HelloName.call(myObject);
运行结果为: 
Hello diz song glad to meet you! 
Hello my Object glad to meet you! 
例2: 

function sum(num1, num2) { 
<pre name="code" class="javascript">  <span style="font-family: Arial, Helvetica, sans-serif;">return num1 + num2; </span>
} console.log(sum.call(window, 10, 10)); //20 console.log(sum.apply(window,[10,20])); //30

 分析:在例1中,我们发现apply()和call()的真正用武之地是能够扩充函数赖以运行的作用域,如果我们想用传统的方法实现,请见下面的代码: 

window.firstName = "diz"; 
window.lastName = "song"; 
var myObject = { firstName: "my", lastName: "Object" }; 
function HelloName() { 
<pre name="code" class="javascript">  <span style="font-family: Arial, Helvetica, sans-serif;">console.log("Hello " + this.firstName + " " + this.lastName, " glad to meet you!"); </span>
} HelloName(); //Hello diz song glad to meet you! myObject.HelloName = HelloName; myObject.HelloName(); //Hello my Object glad to meet you!

 见加红的代码,我们发现,要想让HelloName()函数的作用域在对象myObject上,我们需要动态创建myObject的HelloName属性,此属性作为指针指向HelloName()函数,这样,当我们调用myObject.HelloName()时,函数内部的this变量就指向myObjecct,也就可以调用该对象的内部其他公共属性了。  

通过分析例2,我们可以看到call()和apply()函数的真正运用之处,在实际项目中,还需要根据实际灵活加以处理! 

一个小问题:再看一看函数中定义函数时,this变量的情况

function temp1() { 
<pre name="code" class="javascript">  <span style="font-family: Arial, Helvetica, sans-serif;">console.log(this); //Object {} </span>
  <span style="font-family: Arial, Helvetica, sans-serif;">function temp2() { </span>
      <span style="font-family: Arial, Helvetica, sans-serif;">console.log(this); //Window </span>
  <span style="font-family: Arial, Helvetica, sans-serif;">} </span>
  <span style="font-family: Arial, Helvetica, sans-serif;">temp2(); </span>
} var Obj = {}; temp1.call(Obj); //运行结果见上面绿色的注释!!!!

 执行结果与下面的相同:  

function temp1() { 
    console.log(this); 
    temp2(); 
} 
function temp2() { 
    console.log(this); 
} 
var Obj = {}; 
temp1.call(Obj); 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值