apply&&call&&bind

用来转变函数的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,"试验小学","六年级")();
    原文作者:影绰
    原文地址: https://segmentfault.com/a/1190000013915024
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞