用来改变函数的this对象的指向
- 都是用来改变函数的this对象的指向的。
- 第一个参数都是this要指向的对象。
- 后面的参数是调用方法的参数。
- 都可以利用后续参数传参。
var xw={
name: "小王",
gender: "男",
age: 24,
say: function(){
alert(this.name+" , "+this.gender+" ,今年"+this.age);
}
}
var xh={
name: "小红",
gender: "女",
age: 18
}
xw.say();
调用:
xw.say.call(xh);
xw.say.apply(xh);
// call和apply都是对函数的直接调用,而bind方法返回的仍然是一个函数
xw.say.bind(xh)();
在有参数的情况下call和apply产生区别:
var xw={
name: "小王",
gender: "男",
age: 24,
say: function(school,grade){
alert(this.name+" , "+this.gender+" ,今年"+this.age+" ,在"+school+"上"+grade);
}
}
var xh={
name: "小红",
gender: "女",
age: 18
}
调用形式:
- call以及bind后面的参数与say方法中是一一对应的
- apply的第二个参数是一个数组,数组中的元素是和say方法中一一对应的
xw.say.call(xh,"实验小学","六年级");
xw.say.apply(xh,["实验小学","六年级"]);
xw.say.bind(xh,"实验小学","六年级")();
**粗体** _斜体_ [链接](http://example.com) `代码` - 列表 > 引用
。你还可以使用@
来通知其他用户。