JavaScript中apply、call和bind的区别
2015-11-26 18:04
393 查看
在JS中apply、call和bind都是用来改变函数的this对象的指向的,他们相似的地方如下:
1、都是用来改变函数的this对象的指向;
2、第一个参数都是this要指向的对象;
3、都可以利用后续参数传参;
var person1={
name :"xiaoming",
age:11,
say:function(school,grade){
alert(this.name + " , " + this.age + " ,在" + school + "上" + grade)
}
}
var person2={
name:"xiaohong",
age:12
}就上面例子而言,如何用person1的say方法来显示person2的数据。
1、call的方法是:person1.say.call(person2, "qq小学", “一年级");
2、apply的方法是:person1.apply.call(person2, ["qq小学", “一年级"]);
3、bind的方法是:person1.say.bind(person2)( "qq小学", “一年级");
1、都是用来改变函数的this对象的指向;
2、第一个参数都是this要指向的对象;
3、都可以利用后续参数传参;
var person1={
name :"xiaoming",
age:11,
say:function(school,grade){
alert(this.name + " , " + this.age + " ,在" + school + "上" + grade)
}
}
var person2={
name:"xiaohong",
age:12
}就上面例子而言,如何用person1的say方法来显示person2的数据。
1、call的方法是:person1.say.call(person2, "qq小学", “一年级");
2、apply的方法是:person1.apply.call(person2, ["qq小学", “一年级"]);
3、bind的方法是:person1.say.bind(person2)( "qq小学", “一年级");
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- JavaScript 各种遍历方式详解
- call/apply/bind 的理解与实例分享
- 如何创建对象以及jQuery中创建对象的方式
- IE8开发人员工具教程(二)
- 在flex中执行一个javascript方法的简单方式