题目
下面有关JavaScript中 call和apply的描述,错误的是?
A.call与apply都属于Function.prototype的一个方法,所以每个function实例都有call、apply属性
B.两者传递的参数不同,call函数第一个参数都是要传入给当前对象的对象,apply不是
C.apply传入的是一个参数数组,也就是将多个参数组合成为一个数组传入
D.call传入的则是直接的参数列表。call 方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj 指定的新对象。
解答
正确答案是 B
call()方法和apply()方法的作用相同,他们的区别在于接收参数的方式不同。对于call(),第一个参数是this值没有变化,变化的是其余参数都直接传递给函数。(在使用call()方法时,传递给函数的参数必须逐个列举出来。使用apply()时,传递给函数的是参数数组)如下代码做出解释:
function add(c, d){
return this.a + this.b + c + d;
}
var o = {a:1, b:3};
add.call(o, 5, 7); // 1 + 3 + 5 + 7 = 16
add.apply(o, [10, 20]); // 1 + 3 + 10 + 20 = 34
迷茫很久也看过各式各样的答案,选不出一条自己的路真的很焦灼。没有想到原来大家的路也是一样的颠簸。
现在互联网各个职位的壁垒已经有了,再也不是稍微会点就能入行的年代了,现在的职位一脚开始拒绝培训班出来的人了,除非你有自己的作品或者有工作经验才行。
在使用call()方法时,传递给函数的参数必须逐个列举出来。使用apply()时,传递给函数的是参数数组
call和apply的第一个参数是一样的,都是函数中this的指向对象
B错在两者传递的第一个参数相同,都是当前对象,不同的·是call后来传递的是一个一个参数,apply传递的则是一个参数数组
都是调用对象的方法。
第一个参数是函数运行的作用域(this)
涉及知识点是函数的方法 看回高程3的第五章
我们可以将call()和apply()看作是某个对象的方法,通过调用方法的形式间接调用函数。它们的第一个实参都是要调用函数的母对象,通过调用上下文,在函数体内通过this来获得对它的引用。apply的第二个参数是个数组对象。(谨记这个知识点,要找工作了,好慌)
比博客里罗里吧嗦的好多了