一、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ù)