一、call 方法

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

即  “某个方法”当做“指定的某个对象”的“方法”被执行。

Js代码

call([thisObj[,arg1[, arg2[, [,.argN]]]]])

参数

thisObj

可选项。将被用作当前对象的对象。

arg1, arg2, , argN

可选项。将被传递方法参数序列。

说明

call 方法可以用来代替另一个对象调用一个方法。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。如果没有提供 thisObj 参数,那么 Global 对象被用作 thisObj。

举例一:

01 <input type="text" id="myText" value="input text">
02 function Obj(){
03     this.value = "对象!";
04 }
05  
06 var value = "global 变量";
07  
08 function Fun1() {
09     alert(this.value);
10 }
11  
12 window.Fun1(); //global 变量
13 Fun1.call(window); //global 变量
14 Fun1.call(document.getElementById('myText')); //input text
15 Fun1.call(new Obj()); //对象!

举例二:

01 var first_object = {
02     num: 42
03 };
04  
05 var second_object = {
06     num: 24
07 };
08  
09 function multiply(mult) {
10     return this.num * mult;
11 }
12  
13 multiply.call(first_object, 5); // returns 42 * 5
14 multiply.call(second_object, 5); // returns 24 * 5

二、apply方法

apply方法的第一个参数也是要传入给当前对象的对象,即函数内部的this。后面的参数都是传递给当前对象的参数。

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

01 var func = new function() {
02     this.a = "func";
03 }
04  
05 var myfunc = function(x, y) {
06     var a = "myfunc";
07     alert(this.a);
08     alert(x + y);
09 }
10  
11 myfunc.call(func, "var""fun"); // "func" "var fun"
12 myfunc.apply(func, ["var""fun"]); // "func" "var fun"

三、caller 属性

返回一个对函数的引用,即调用了当前函数的函数体。

functionName.caller :functionName 对象是所执行函数的名称。

说明

对 于函数来说,caller 属性只有在函数执行时才有定义。 如果函数是由 JScript 程序的顶层调用的,那么 caller 包含的就是 null 。如果在字符串上下文中使用 caller 属性,那么结果和 functionName.toString 一样,也就是说,显示的是函数的反编译文本。

01 function CallLevel(){
02     if (CallLevel.caller == null) {
03         alert("CallLevel was called from the top level.");
04     else {
05         alert("CallLevel was called by another function:\n" + CallLevel.caller);
06     }
07 }
08  
09 function funCaller(){
10     CallLevel();
11 }
12  
13 CallLevel();
14 funCaller()

四、callee属性

返回正被执行的 Function 对象,也就是所指定的 Function 对象的正文。

[function.]arguments.callee:可选项 function 参数是当前正在执行的 Function 对象的名称。

说明

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

01 // callee可以打印其本身
02 function calleeDemo() {
03     alert(arguments.callee);
04 }
05  
06 // 用于验证参数
07 function calleeLengthDemo(arg1, arg2) {
08     if (arguments.length == arguments.callee.length) {
09         window.alert("验证形参和实参长度正确!");
10         return;
11     else {
12         alert("实参长度:" + arguments.length);
13         alert("形参长度: " + arguments.callee.length);
14     }
15 }
16  
17 //递归计算
18 var sum = function(n){
19     if (n <= 0) {
20         return 1;
21     else {
22         return n + arguments.callee(n - 1);
23     }
24 }

五、bind

01 var first_object = {
02     num: 42
03 };
04  
05 var second_object = {
06     num: 24
07 };
08  
09 function multiply(mult) {
10     return this.num * mult;
11 }
12  
13 Function.prototype.bind = function(obj) {
14     var method = this,
15     temp = function() {
16         return method.apply(obj, arguments);
17     };
18  
19     return temp;
20 }
21  
22 var first_multiply = multiply.bind(first_object);
23 first_multiply(5); // returns 42 * 5
24  
25 var second_multiply = multiply.bind(second_object);
26 second_multiply(5); // returns 24 * 5

+++++++++++++++++++++++++++++++++++++++++++++++++++++

caller 与 callee 区别的一些举例:

01 <script type = 'text/javascript'>
02 function a() {
03     b();
04 }
05  
06 function b() {
07     alert(b === arguments.callee)
08     alert(b.caller === a)
09     alert(arguments.callee.caller === a)
10 }
11 a();
12  
13 </script>

//———-

01 <script type="text/javascript">
02 function calleeTest() {
03     arguments.callee.say("Mr.CT""您好!"); // 获取当前函数句柄
04 }
05  
06 calleeTest.say = function(userName, value) {
07     alert(userName + "说:" + value);
08 };
09  
10 function callerTest() {
11     (function() {
12         arguments.callee.caller.goodbye("Mr.CT""Canca Torvals"); // 获取调用当前函数的函数
13     })();
14 }
15  
16 callerTest.goodbye = function(userName, userName2) {
17     alert(userName + " 向 " + userName2 + " 说再见.");
18 };
19  
20 calleeTest();
21 callerTest();
22 </script>

 

JavaScript方法call,apply,caller,callee,bind的使用详解及区别的更多相关文章

  1. js call apply caller callee bind

    call apply bind作用类似.即调用一个对象的一个方法,以另一个对象替换当前对象. call 语法:call([thisObj[,arg1[, arg2[,   [,.argN]]]]]) ...

  2. JavaScript方法call、apply、caller、callee、bind的使用详解及区别

    一.call 方法 调用一个对象的一个方法,以另一个对象替换当前对象(其实就是更改对象的内部指针,即改变对象的this指向的内容). 即  “某个方法”当做“指定的某个对象”的“方法”被执行. Js代 ...

  3. javascript下的arguments,caller,callee,call,apply示例及理解

    (参考:http://justcoding.iteye.com/blog/589111) Arguments  该对象代表正在执行的函数和调用它的函数的参数. [function.]arguments ...

  4. javascript中 Function.prototype.apply()与Function.prototype.call() 对比详解

    Function.prototype.apply()|Function.prototype.call() apply()方法可以在使用一个指定的 this 值和一个参数数组(或类数组对象)的前提下调用 ...

  5. JavaScript中return的用法和this的用法详解

    JavaScript中return的用法详解 最近,跟身边学前端的朋友了解,有很多人对this和函数中的return的用法和意思理解的比较模糊,这里写一篇博客跟大家一起探讨一下return和this的 ...

  6. js apply/call/caller/callee/bind使用方法与区别分析

    一.call 方法 调用一个对象的一个方法,以另一个对象替换当前对象(其实就是更改对象的内部指针,即改变对象的this指向的内容). Js代码 call([thisObj[,arg1[, arg2[, ...

  7. js经验点滴js apply/call/caller/callee/bind使用方法与区别分析

    一.call 方法 调用一个对象的一个方法,以另一个对象替换当前对象(其实就是更改对象的内部指针,即改变对象的this指向的内容). Js代码 call([thisObj[,arg1[, arg2[, ...

  8. 彻底理解了call()方法,apply()方法和bind()方法

    javascript中的每一个作用域中都有一个this对象,它代表的是调用函数的对象.在全局作用域中,this代表的是全局对象(在web浏览器中指的是window).如果包含this的函数是一个对象的 ...

  9. 浅谈JavaScript中的apply,call和bind

    apply,call,bine 这三兄弟经常让初学者感到疑惑.前两天准备面试时特地做了个比较,其实理解起来也不会太难. apply MDN上的定义: The apply() method calls ...

随机推荐

  1. js实现去重字符串

    实现去重字符串主要是把重复的字符与原来的字符(先push()进入一个数组存起来)相匹配,如果match返回的不是null则说明重复,就删除掉: <script> var str = pro ...

  2. 关于Xcode8.1 / iOS10+ 真机测试系统打印或者宏定义打印不显示问题

    前言: 最近做项目时遇到了很多莫名其妙的问题,其中就有这个打印(NSLog).也不多废话了,我们先来回顾一下Xcode8发布以来,我们遇到的一些关于打印的问题,当然也有解决方法: 1.Xcode8打印 ...

  3. 【Oracle】ora-28001 ora-28002提示用户密码即将过期的解决办法

    -- 1.首先查看用户的配置文件中的用户密码生命周期,一般情况下默认是180天.登录时系统提示ora-28002该用户即将过期 -- 可以先查看一下各用户的状态 SELECT username,PRO ...

  4. JS:事件对象1

    一,this关键字和上下文 var box = document.getElementById("box");. 普通的函数如果没有给他传递参数,函数本身是没有参数的. test( ...

  5. 随堂笔记javascript篇之chrome调试:

    在征求到许老师的同意之后,我用javascript脚本语言来完成我的课堂作业,初学一门语言,刚开始也许是初生牛犊不怕虎,接受一门新的语言而且用来完成作业.一开始老师是拒绝的,他说我这样是太麻烦了.对于 ...

  6. Undefined symbols for architecture x86_64: "_OBJC_CLASS_$_The49DayPersonalFullscreenGiftModel", referenced from: objc-class-ref in The49DayPersonalRoomGiftModel.o ld: symbol(s) not found for a

    Undefined symbols for architecture x86_64: "_OBJC_CLASS_$_The49DayPersonalFullscreenGiftModel&q ...

  7. *HDU1151 二分图

    Air Raid Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Su ...

  8. iOS CADisplayLink 定时器的使用

    CADisplayLink 是一个能让我们以和屏幕刷新频率相同的频率将内容刻画到屏幕上的定时器,在应用中创建一个新的CADisplayLink对象,把他添加到一个runloop中,并且给他提供一个ta ...

  9. poj1131-Octal Fractions(进制转换)

    一,题意: 求一个八进制小数的十进制.二,思路: 暴力数组模拟计算,注意千万不带小数做除法运算 1,对于八进制小数,转换成十进制,书写形式分析: 2,对其除法过程进行模拟: 3,输出. 三,步骤: 1 ...

  10. PHP 数组的拷贝是按值传递 or 按引用传递

    在记忆中 PHP 简单变量的拷贝是按值传递,数组和对象的拷贝是按引用传递,即通过引用来实现. 简单变量和对象好理解: <?php // 简单变量的拷贝 $a = 'human'; $b = $a ...