JavaScript Function.apply() 函数详解
Posted 前端白雪
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaScript Function.apply() 函数详解相关的知识,希望对你有一定的参考价值。
JavaScript Function.apply() 函数详解 apply()函数用于调用当前函数functionObject,并可同时使用指定对象thisObj作为本次函数执行时函数内部的this指针引用。 该函数属于Function对象,所有主流浏览器均支持该函数。 语法 functionObject.apply( [ thisObj [, argsArray ]] ) 参数 参数 描述 thisObj 可选/Object类型指定执行functionObject函数时,函数内部this指针引用的对象。 argsArray 可选/Array|argumens对象调用functionObject函数时所传入的参数数组或arguments对象。 如果提供了argsArray参数,则该参数必须是一个数组,或者arguments对象。数组中的每个元素(arguments对象中的每个属性0...n)将按照顺序作为参数传入该函数。 如果提供了argsArray参数,则必须提供thisObj参数。 备注:该函数与Function对象的call()函数作用相同,只不过call()函数是将Function对象的参数一个个分别传入,apply()函数是将Function对象的参数以一个数组或arguments对象的形式整体传入。 返回值 apply()方法的返回值为任意类型,其返回值取决于当前functionObject对象的返回值。 示例&说明 name = "张三"; age = 18; function test() document.writeln(this); document.writeln(this.name); document.writeln(this.age); ; // 全局函数内部的this默认为全局对象window test(); // [object Window] 张三 18 var obj = name: "李四", age: 20; // 更改内部的this指针引用对象为obj test.apply(obj); // [object Object] 李四 20 function foo(a, b) document.writeln(this.name); document.writeln(a); document.writeln(b); // 改变this引用为obj,同时传递两个参数 foo.apply(obj, [12, true]); // 李四 12 true function bar() var o = name: "王五"; // 调用foo()函数,并改变其this为对象o,传入当前函数的参数对象arguments作为其参数 foo.apply(o, arguments); bar("CodePlayer", "www.365mini.com"); // 王五 CodePlayer www.365mini.com call 和 apply 都是为了改变某个函数运行时的 context 即上下文而存在的,换句话说,就是为了改变函数体内部 this 的指向。因为 JavaScript 的函数存在「定义时上下文」和「运行时上下文」以及「上下文是可以改变的」这样的概念。 二者的作用完全一样,只是接受参数的方式不太一样。例如,有一个函数 func1 定义如下: var func1 = function(arg1, arg2) ; 就可以通过 func1.call(this, arg1, arg2); 或者 func1.apply(this, [arg1, arg2]); 来调用。其中 this 是你想指定的上下文,他可以任何一个 JavaScript 对象(JavaScript 中一切皆对象),call 需要把参数按顺序传递进去,而 apply 则是把参数放在数组里。 JavaScript 中,某个函数的参数数量是不固定的,因此要说适用条件的话,当你的参数是明确知道数量时,用 call,而不确定的时候,用 apply,然后把参数 push 进数组传递进去。当参数数量不确定时,函数内部也可以通过 arguments 这个数组来便利所有的参数。 龙腾一族至尊龙骑
以上是关于JavaScript Function.apply() 函数详解的主要内容,如果未能解决你的问题,请参考以下文章
08.24 javascript 内置对象 function apply() * call() * bind() ECMA5新增