call与apply

来源:互联网 发布:pe系统网络组件下载 编辑:程序博客网 时间:2024/05/16 15:42

想了好久都没懂这俩到时是怎么区分  一直模模糊糊 一做题就懵逼了

今天看到这样一道题:

下面有关JavaScript中 call和apply的描述,错误的是?

正确答案: B   你的答案: D (错误)

call与apply都属于Function.prototype的一个方法,所以每个function实例都有call、apply属性
两者传递的参数不同,call函数第一个参数都是要传入给当前对象的对象,apply不是
apply传入的是一个参数数组,也就是将多个参数组合成为一个数组传入
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 



还有几道这种题,一起贴上来,长记性。

请阅读以下代码:
1
2
3
var obj = {};
obj.log= console.log;
obj.log.call(console,this);
该代码在浏览器中执行,输出的日志结果是什么?

正确答案: A   你的答案: D (错误)

window
console
obj
undefined




0 0
原创粉丝点击