javascript中apply,call和bind的区别
1个回答
展开全部
1 call(), apply(),bind()都属于Function.prototype的一个内置方法,它是JavaScript引擎内在实现的,因为属于Function.prototype,主要就是围绕这this对象的改变操作。下面已代码逐一展示各自的用法。
2 var a = {
user:"call调用",
fn:function(){
console.log(this.user); //对应的user
}
}
var b = a.fn;
b.call(a);
意思是:call方法,给第一个参数添加要把b添加到哪个环境中,简单来说,this就会指向那个对象。
3 var a = {
user:"applay调用",
fn:function(){
console.log(this.user); // applay调用
}
}
var b = a.fn;
b.apply(a);
apply方法和call方法有些相似,它也可以改变this的指向;不同的是 ,但是不同的是,第二个参数必须是一个数组 如下代码
var a = {
user:"appy调用",
fn:function(e,ee){
console.log(this.user); // applay调用 第二个参数书数组
console.log(e+ee);
}
}
var b = a.fn;
b.apply(a,[10,1]);
4 上bind方法返回的是一个修改过后的函数
var a = {
user:"bind调用",
fn:function(){
console.log(this.user);
}
}
var b = a.fn;
b.bind(a);
2 var a = {
user:"call调用",
fn:function(){
console.log(this.user); //对应的user
}
}
var b = a.fn;
b.call(a);
意思是:call方法,给第一个参数添加要把b添加到哪个环境中,简单来说,this就会指向那个对象。
3 var a = {
user:"applay调用",
fn:function(){
console.log(this.user); // applay调用
}
}
var b = a.fn;
b.apply(a);
apply方法和call方法有些相似,它也可以改变this的指向;不同的是 ,但是不同的是,第二个参数必须是一个数组 如下代码
var a = {
user:"appy调用",
fn:function(e,ee){
console.log(this.user); // applay调用 第二个参数书数组
console.log(e+ee);
}
}
var b = a.fn;
b.apply(a,[10,1]);
4 上bind方法返回的是一个修改过后的函数
var a = {
user:"bind调用",
fn:function(){
console.log(this.user);
}
}
var b = a.fn;
b.bind(a);
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询