`
java-mans
  • 浏览: 11342741 次
文章分类
社区版块
存档分类
最新评论

js的call方法 apply方法 caller属性 callee属性

 
阅读更多

js的call方法_apply方法_caller属性_callee属性

原文地址:http://aweber.blogbus.com/logs/46751586.html

一、call 方法
调用一个对象的一个方法,以另一个对象替换当前对象(其实就是更改对象的内部指针,即改变对象的this指向的内容)。

Js代码
  1. call([thisObj[,arg1[,<wbr>arg2[,<wbr><wbr><wbr>[,.argN]]]]])</wbr></wbr></wbr></wbr>

参数
thisObj
可选项。将被用作当前对象的对象。
arg1, arg2,<wbr><wbr> , argN<br> 可选项。将被传递方法参数序列。<br> 说明<br> call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj指定的新对象。如果没有提供 thisObj 参数,那么 Global 对象被用作 thisObj。</wbr></wbr>

Js代码
  1. <input<wbr>type=</wbr>“text”id=“myText”value=“input<wbr>text”</wbr>>
  2. <script>
  3. functionObj(){this.value=“对象!”;}
  4. varvalue=“global<wbr>变量”</wbr>;
  5. functionFun1(){alert(this.value);}

  6. window.Fun1();<wbr><wbr><wbr><span>//global<wbr>变量</wbr></span></wbr></wbr></wbr>
  7. Fun1.call(window);<wbr><wbr><span>//global<wbr>变量</wbr></span></wbr></wbr>
  8. Fun1.call(document.getElementByIdx_x_x(‘myText’));//input<wbr>text</wbr>
  9. Fun1.call(new Obj());//对象!
  10. </script>
Js代码
  1. varfirst_object<wbr>=<wbr>{</wbr></wbr>
  2. num:<wbr>42</wbr>
  3. };
  4. varsecond_object<wbr>=<wbr>{</wbr></wbr>
  5. num:<wbr>24</wbr>
  6. };
  7. functionmultiply(mult)<wbr>{</wbr>
  8. returnthis.num<wbr>*<wbr>mult;</wbr></wbr>
  9. }
  10. multiply.call(first_object,<wbr>5);<wbr><span>//<wbr>returns<wbr>42<wbr>*<wbr>5</wbr></wbr></wbr></wbr></span></wbr></wbr>
  11. multiply.call(second_object,<wbr>5);<wbr><span>//<wbr>returns<wbr>24<wbr>*<wbr>5</wbr></wbr></wbr></wbr></span></wbr></wbr>

二、apply方法
apply方法的第一个参数也是要传入给当前对象的对象,即函数内部的this。后面的参数都是传递给当前对象的参数。
对于apply和call两者在作用上是相同的,但两者在参数上有区别的。对于第一个参数意义都一样,但对第二个参数:apply传入的是一个参数数组,也就是将多个参数组合成为一个数组传入,而call则作为call的参数传入(从第二个参数开始)。
如 func.call(func1,var1,var2,var3)对应的apply写法为:func.apply(func1,[var1,var2,var3])同时使用apply的好处是可以直接将当前函数的arguments对象作为apply的第二个参数传入。

Js代码
  1. var func=newfunction(){this.a=“func”}
  2. varmyfunc=function(x,y){
  3. vara=“myfunc”;
  4. alert(this.a);
  5. alert(x<wbr>+<wbr>y);</wbr></wbr>
  6. }
  7. myfunc.call(func,“var”,“<wbr>fun”</wbr>);//<wbr>”func”<wbr>”var<wbr>fun”</wbr></wbr></wbr>
  8. myfunc.apply(func,["var","<wbr>fun"</wbr>]);//<wbr>”func”<wbr>”var<wbr>fun”</wbr></wbr></wbr>

三、caller 属性
返回一个对函数的引用,即调用了当前函数的函数体。
functionName.caller :functionName 对象是所执行函数的名称。
说明:
对于函数来说,caller 属性只有在函数执行时才有定义。 如果函数是由 JScript 程序的顶层调用的,那么 caller包含的就是 null 。如果在字符串上下文中使用 caller 属性,那么结果和 functionName.toString一样,也就是说,显示的是函数的反编译文本。

Js代码
  1. <script>
  2. functionCallLevel(){
  3. if(CallLevel.caller<wbr>==</wbr>null)
  4. alert(“CallLevel<wbr>was<wbr>called<wbr>from<wbr>the<wbr>top<wbr>level.”</wbr></wbr></wbr></wbr></wbr></wbr>);
  5. else
  6. alert(“CallLevel<wbr>was<wbr>called<wbr>by<wbr>another<wbr>function:\n”</wbr></wbr></wbr></wbr></wbr>+CallLevel.caller);
  7. }
  8. functionfunCaller(){
  9. CallLevel();
  10. }
  11. CallLevel();
  12. funCaller()
  13. </script>

四、callee属性
返回正被执行的 Function 对象,也就是所指定的 Function 对象的正文。
[function.]arguments.callee:可选项 function 参数是当前正在执行的 Function对象的名称。
说明:
callee 属性的初始值就是正被执行的 Function 对象。
callee 属性是 arguments 对象的一个成员,它表示对函数对象本身的引用,这有利于匿
函数的递归或者保证函数的封装性,例如下边示例的递归计算1到n的自然数之和。而该属性
仅当相关函数正在执行时才可用。还有需要注意的是callee拥有length属性,这个属性有时
用于验证还是比较好的。arguments.length是实参长度,arguments.callee.length是
形参长度,由此可以判断调用时形参长度是否和实参长度一致。

Js代码
  1. //callee可以打印其本身
  2. functioncalleeDemo()<wbr>{</wbr>
  3. alert(arguments.callee);
  4. }
  5. //用于验证参数
  6. functioncalleeLengthDemo(arg1,<wbr>arg2)<wbr>{</wbr></wbr>
  7. if(arguments.length==arguments.callee.length)<wbr>{</wbr>
  8. window.alert(“验证形参和实参长度正确!”);
  9. return;
  10. }<wbr><span>else</span><span>{</span></wbr>
  11. alert(“实参长度:”+arguments.length);
  12. alert(“形参长度:<wbr>”</wbr>+arguments.callee.length);
  13. }
  14. }
  15. //递归计算
  16. var sum<wbr>=</wbr>function(n){
  17. if(n<wbr>&lt;=<wbr>0)</wbr></wbr>
  18. return 1;
  19. else
  20. returnn<wbr>+arguments.callee(n<wbr>-<wbr>1)</wbr></wbr></wbr>
  21. }

五、bind

Js代码
  1. <script<wbr>type=</wbr>“text/javascript”>
  2. varfirst_object<wbr>=<wbr>{</wbr></wbr>
  3. num:<wbr>42</wbr>
  4. };
  5. varsecond_object<wbr>=<wbr>{</wbr></wbr>
  6. num:<wbr>24</wbr>
  7. };

  8. functionmultiply(mult)<wbr>{</wbr>
  9. returnthis.num<wbr>*<wbr>mult;</wbr></wbr>
  10. }

  11. Function.prototype.bind<wbr>=<wbr><span>function</span><span>(obj)<wbr>{</wbr></span></wbr></wbr>
  12. var method<wbr>=</wbr>this,
  13. temp<wbr>=<wbr><span>function</span><span>()<wbr>{</wbr></span></wbr></wbr>
  14. returnmethod.apply(obj,<wbr>arguments);</wbr>
  15. };

  16. return temp;
  17. }

  18. varfirst_multiply<wbr>=<wbr>multiply.bind(first_object);</wbr></wbr>
  19. first_multiply(5);<wbr><span>//<wbr>returns<wbr>42<wbr>*<wbr>5</wbr></wbr></wbr></wbr></span></wbr>

  20. varsecond_multiply<wbr>=<wbr>multiply.bind(second_object);</wbr></wbr>
  21. second_multiply(5);<wbr><span>//<wbr>returns<wbr>24<wbr>*<wbr>5</wbr></wbr></wbr></wbr></span></wbr>
  22. </script>

分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics