一、call,apply,bind的相同點:
都是改變this指向的;
第一個參數(shù)都是this要指向的對象;
都可以利用后續(xù)參數(shù)傳參;
二、call,apply,bind的區(qū)別:
call和bind的參數(shù)是依次傳參,一一對應的;
但apply只有兩個參數(shù),第二個參數(shù)為數(shù)組;
call和apply都是對函數(shù)進行直接調用(函數(shù)已經執(zhí)行),而bind方法返回的仍是一個函數(shù)(新生成一個新的函數(shù));
const person = {
name: "小明",
age : 16,
hobby:"打游戲",
score:100,
speak:function(hobby,score){
console.log("名字",this.name,"年齡",this.age,hobby,score);
}
}
person.speak();
let p1 = {name:"小敏",age:17};
person.speak.call(p1,"吹牛皮",90);
//改變speak中this的指向 為p1。 并同時執(zhí)行, 同時參數(shù)按照順序傳遞
let p2 = {name:"小小強",age:18};
person.speak.apply(p2,["唱歌",20]);
//改變speak中this的指向 為p2。 并同時執(zhí)行, 參數(shù)只有兩個,且第二個必須為數(shù)組
let p3 = {name:"小王",age:19};
let pp = person.speak.bind(p3,"游泳",96);
//改變speak中this的指向為p3, 但并沒有執(zhí)行,返回一個新的函數(shù), 傳遞參數(shù)按照順序執(zhí)行
pp(); //執(zhí)行新的函數(shù)