一、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" >
|
06
|
var value
= "global
变量" ;
|
14
|
Fun1.call(document.getElementById( 'myText' ));
|
举例二:
09
|
function multiply(mult)
{
|
10
|
return this .num
* mult;
|
13
|
multiply.call(first_object,
5);
|
14
|
multiply.call(second_object,
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 ()
{
|
05
|
var myfunc
= function (x,
y) {
|
11
|
myfunc.call(func, "var" , "fun" );
|
12
|
myfunc.apply(func,
[ "var" , "fun" ]);
|
三、caller 属性
返回一个对函数的引用,即调用了当前函数的函数体。
functionName.caller :functionName 对象是所执行函数的名称。
说明
对 于函数来说,caller 属性只有在函数执行时才有定义。 如果函数是由 JScript 程序的顶层调用的,那么 caller 包含的就是 null 。如果在字符串上下文中使用 caller 属性,那么结果和 functionName.toString 一样,也就是说,显示的是函数的反编译文本。
02
|
if (CallLevel.caller
== null) {
|
03
|
alert( "CallLevel
was called from the top level." );
|
05
|
alert( "CallLevel
was called by another function:\n" +
CallLevel.caller);
|
四、callee属性
返回正被执行的 Function 对象,也就是所指定的 Function 对象的正文。
[function.]arguments.callee:可选项 function 参数是当前正在执行的 Function 对象的名称。
说明
callee 属性的初始值就是正被执行的 Function 对象。
callee 属性是 arguments 对象的一个成员,它表示对函数对象本身的引用,这有利于匿 函数的递归或者保证函数的封装性,例如下边示例的递归计算1到n的自然数之和。而该属性仅当相关函数正在执行时才可用。还有需要注意的是callee拥有length属性,这个属性有时用于验证还是比较好的。arguments.length 是实参长度,arguments.callee.length 是形参长度,由此可以判断调用时形参长度是否和实参长度一致。
02
|
function calleeDemo()
{
|
03
|
alert(arguments.callee);
|
07
|
function calleeLengthDemo(arg1,
arg2) {
|
08
|
if (arguments.length
== arguments.callee.length) {
|
09
|
window.alert( "验证形参和实参长度正确!" );
|
12
|
alert( "实参长度:" +
arguments.length);
|
13
|
alert( "形参长度:
" +
arguments.callee.length);
|
22
|
return n
+ arguments.callee(n - 1);
|
五、bind
09
|
function multiply(mult)
{
|
10
|
return this .num
* mult;
|
13
|
Function.prototype.bind
= function (obj)
{
|
16
|
return method.apply(obj,
arguments);
|
22
|
var first_multiply
= multiply.bind(first_object);
|
25
|
var second_multiply
= multiply.bind(second_object);
|
+++++++++++++++++++++++++++++++++++++++++++++++++++++
caller 与 callee 区别的一些举例:
01
|
<script
type = 'text/javascript' >
|
07
|
alert(b
=== arguments.callee)
|
09
|
alert(arguments.callee.caller
=== a)
|
//———-
01
|
<script
type= "text/javascript" >
|
02
|
function calleeTest()
{
|
03
|
arguments.callee.say( "Mr.CT" , "您好!" );
|
06
|
calleeTest.say
= function (userName,
value) {
|
07
|
alert(userName
+ "说:" +
value);
|
10
|
function callerTest()
{
|
12
|
arguments.callee.caller.goodbye( "Mr.CT" , "Canca
Torvals" );
|
16
|
callerTest.goodbye
= function (userName,
userName2) {
|
17
|
alert(userName
+ "
向 " +
userName2 + "
说再见." );
|
分享到:
相关推荐
理解JavaScript的caller callee call apply
js apply/call/caller/callee/bind使用方法与区别分析,需要的朋友可以参考下。
NULL 博文链接:https://cuckoosnest.iteye.com/blog/470131
主要介绍了javascript中call,apply,callee,caller用法,结合实例形式分析了javascript中call,apply,callee,caller功能、使用方法及相关操作注意事项,需要的朋友可以参考下
NULL 博文链接:https://davidxiaozhi.iteye.com/blog/1026937
理解Javascript的caller,callee,call,apply区别
Javascript – 全面理解 caller,callee,call,apply Author: BlueDestiny, never-online From: http://www.never-online.net, Blog.csdn.net/BlueDestiny 1、caller JScript参考中说明为:返回一个对函数的...
js中arguments,caller,callee,apply的用法小结.docx
有些小伙伴可能会问caller,callee 是什么?在javascript 中有什么样的作用?那么本篇会对于此做一些基本介绍。希望能够对大家理解javascript中的callee与caller有所帮助。
本文实例讲述了JavaScript中callee和caller的区别与用法。分享给大家供大家参考,具体如下: 1.callee 在函数的内部,有两个特殊的对象:arguments和this。其中arguments是一个类似数组的对象,包含着传入函数的所有...
javascript中arguments,caller,callee 是什么?在javascript 中有什么样的作用?本篇会对于此做一些基本介绍。希望大家能够喜欢。
有些小伙伴可能会问caller,callee 是什么?在javascript 中有什么样的作用?那么本篇会对于此做一些基本介绍。希望能够对大家理解javascript中的callee与caller有所帮助。
挺好的,虽然我用的是jQuery,但感觉还是有些用的~~~
Javascript原型对象、this的5钟用法、原型继承、Caller和Callee的使用.docx
在看到大家如此关注JS里头的这几个对象,我试着把原文再修改一下,力求能再详细的阐明个中意义
javascript中callee和caller的用法和应用场景分析,需要的朋友可以参考下。