李如凤 發表於 2022-3-25 09:53:00

JavaScript Function.apply() 函数详解

<div class="cnblogs_code">
<pre><span style="color: rgba(0, 0, 0, 1)">JavaScript Function.apply() 函数详解
apply()函数用于调用当前函数functionObject,并可同时使用指定对象thisObj作为本次函数执行时函数内部的this指针引用。

该函数属于Function对象,所有主流浏览器均支持该函数。

语法
functionObject.apply( [ thisObj [, argsArray ]] )
参数
参数    描述
thisObj    可选</span>/<span style="color: rgba(0, 0, 0, 1)">Object类型指定执行functionObject函数时,函数内部this指针引用的对象。
argsArray    可选</span>/Array|<span style="color: rgba(0, 0, 0, 1)">argumens对象调用functionObject函数时所传入的参数数组或arguments对象。
如果提供了argsArray参数,则该参数必须是一个数组,或者arguments对象。数组中的每个元素(arguments对象中的每个属性0...n)将按照顺序作为参数传入该函数。

如果提供了argsArray参数,则必须提供thisObj参数。

备注:该函数与Function对象的call()函数作用相同,只不过call()函数是将Function对象的参数一个个分别传入,apply()函数是将Function对象的参数以一个数组或arguments对象的形式整体传入。

返回值
apply()方法的返回值为任意类型,其返回值取决于当前functionObject对象的返回值。

示例</span>&amp;<span style="color: rgba(0, 0, 0, 1)">说明
name </span>= <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">张三</span><span style="color: rgba(128, 0, 0, 1)">"</span>; age = <span style="color: rgba(128, 0, 128, 1)">18</span><span style="color: rgba(0, 0, 0, 1)">;
function test(){   
document.writeln(</span><span style="color: rgba(0, 0, 255, 1)">this</span><span style="color: rgba(0, 0, 0, 1)">);   
document.writeln(</span><span style="color: rgba(0, 0, 255, 1)">this</span><span style="color: rgba(0, 0, 0, 1)">.name);   
document.writeln(</span><span style="color: rgba(0, 0, 255, 1)">this</span><span style="color: rgba(0, 0, 0, 1)">.age);   
};
</span><span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)"> 全局函数内部的this默认为全局对象window test();
</span><span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)"> 张三 18</span>
<span style="color: rgba(0, 0, 255, 1)">var</span> obj = {name: <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">李四</span><span style="color: rgba(128, 0, 0, 1)">"</span>, age: <span style="color: rgba(128, 0, 128, 1)">20</span><span style="color: rgba(0, 0, 0, 1)">};
</span><span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)"> 更改内部的this指针引用对象为obj</span>
<span style="color: rgba(0, 0, 0, 1)"> test.apply(obj);
</span><span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)"> 李四 20</span>
<span style="color: rgba(0, 0, 0, 1)"> function foo(a, b){   
document.writeln(</span><span style="color: rgba(0, 0, 255, 1)">this</span><span style="color: rgba(0, 0, 0, 1)">.name);
      document.writeln(a);
       document.writeln(b);   
}
</span><span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)"> 改变this引用为obj,同时传递两个参数 </span>
foo.apply(obj, [<span style="color: rgba(128, 0, 128, 1)">12</span>, <span style="color: rgba(0, 0, 255, 1)">true</span><span style="color: rgba(0, 0, 0, 1)">]);
</span><span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)"> 李四 12 true</span>
<span style="color: rgba(0, 0, 0, 1)"> function bar(){   
</span><span style="color: rgba(0, 0, 255, 1)">var</span> o = {name: <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">王五</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">};
   </span><span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)"> 调用foo()函数,并改变其this为对象o,传入当前函数的参数对象arguments作为其参数</span>
<span style="color: rgba(0, 0, 0, 1)">   foo.apply(o, arguments);   
}
bar(</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">CodePlayer</span><span style="color: rgba(128, 0, 0, 1)">"</span>, <span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(128, 0, 0, 1)">www.365mini.com</span><span style="color: rgba(128, 0, 0, 1)">"</span><span style="color: rgba(0, 0, 0, 1)">);
</span><span style="color: rgba(0, 128, 0, 1)">//</span><span style="color: rgba(0, 128, 0, 1)"> 王五 CodePlayer www.365mini.com</span>
<span style="color: rgba(0, 0, 0, 1)">



call 和 apply 都是为了改变某个函数运行时的 context 即上下文而存在的,换句话说,就是为了改变函数体内部 </span><span style="color: rgba(0, 0, 255, 1)">this</span><span style="color: rgba(0, 0, 0, 1)"> 的指向。因为 JavaScript 的函数存在「定义时上下文」和「运行时上下文」以及「上下文是可以改变的」这样的概念。
二者的作用完全一样,只是接受参数的方式不太一样。例如,有一个函数 func1 定义如下:
</span><span style="color: rgba(0, 0, 255, 1)">var</span> func1 =<span style="color: rgba(0, 0, 0, 1)"> function(arg1, arg2) {};

就可以通过 func1.call(</span><span style="color: rgba(0, 0, 255, 1)">this</span>, arg1, arg2); 或者 func1.apply(<span style="color: rgba(0, 0, 255, 1)">this</span>, ); 来调用。其中 <span style="color: rgba(0, 0, 255, 1)">this</span><span style="color: rgba(0, 0, 0, 1)"> 是你想指定的上下文,他可以任何一个 JavaScript 对象(JavaScript 中一切皆对象),call 需要把参数按顺序传递进去,而 apply 则是把参数放在数组里。
JavaScript 中,某个函数的参数数量是不固定的,因此要说适用条件的话,当你的参数是明确知道数量时,用 call,而不确定的时候,用 apply,然后把参数 push 进数组传递进去。当参数数量不确定时,函数内部也可以通过 arguments 这个数组来便利所有的参数。
龙腾一族至尊龙骑</span></pre>
</div>
<p>&nbsp;</p><br><br>
来源:https://www.cnblogs.com/webSnow/p/16053289.html
頁: [1]
查看完整版本: JavaScript Function.apply() 函数详解