call(),apply()方法和类数组对象arguments

 1 <!DOCTYPE html>
 2 <html>
 3     <head>
 4         <meta charset="utf-8">
 5         <title></title>
 6     <script type="text/javascript">
 7    /*
 8    call(),apply()
 9    这两个方法都是函数对象的方法,需要通过函数对象来调用
10    当对函数调用call()和apply()都会调用函数执行
11    在调用call()和apply()可以将一个对象指定为第一个参数
12      此时这个对象将会成为函数执行时的this
13     call()方法可以将实参在对象之后依次传递
14     apply()方法需要将实参封装到一个数组中统一传递
15    */
16   function fun(a,b){
17       console.log("a="+a);
18       console.log("b="+b);
19       alert(this.name);//this是call,apply调用时的第一个参数
20   }
21   var obj={name:"wxy"};
22   var obj2={name:"111"};
23   //fun.call(obj);//wxy
24   //fun.call(obj2);//111
25   fun.call(obj,2,3);
26   fun.apply(obj,[2,3]);
27   /*
28   在调用函数时,浏览器每次都会传递进两个隐含的参数,
29   1.函数的上下文对象this
30   2.封装实参的对象arguments
31     arguments是一个类数组对象,它也可以通过索引来操作数据,也可以获取实参的长度
32     在调用函数时,我们所传递的实参都会封装到arguments中
33     我们即使不定义形参,也可以通过arguments来使用实参
34     arguments[0] 表示第一个实参
35     arguments[1] 表示第二个实参
36     arguments有一个属性叫做callee
37     这个属性对应一个函数对象,就是当前正在指向的函数的对象
38   */
39  
40  function fun2(){
41      console.log(arguments.length);//2
42      console.log(arguments[0]);//12
43  }
44  fun2(12,3);
45     </script>
46     </head>
47     <body>
48     </body>
49 </html>

 

转载于:https://www.cnblogs.com/zuiaimiusi/p/11225176.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值