call()、apply()、bind()
1、首先 每個Function對象里面都存在call()和apply()方法,及在函數的原型里面
2、語法是
? function.apply(thisObj,[a,b,c])??
? function.call(thisObj,a,b,c)
3、共同點
都是 用來代替另一個對象調用一個方法,將一個函數的對象上下文重新改變為thisObj指定的新對象
4、不同點
apply()接受兩個參數,將參數放進數組里面
call()接受多個參數,參數為一串列表
5、例子
function add(a,b){
return a+b;
}
function sub(a,b){
return a-b;
}
var a1 = add.apply(sub,[4,2])
var a2 = sub.apply(add,[4,2])
var a3 = add.call(sub,4,2)
console.log(a1,a2,a3)
6、實現繼承
function Animal(name){
this.name = name;
this.showName = function(){
alert(this.name);
}
}
function Cat(name){
Animal.apply(this,[name]);
}
var cat = new Cat("咕咕");
cat.showName();
/*call的用法*/
Animal.call(this,name);
?
轉載于:https://www.cnblogs.com/lk1186578324/p/9395010.html
總結
以上是生活随笔為你收集整理的call()、apply()、bind()的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: ACM北大暑期课培训第六天
- 下一篇: BZOJ2938: [Poi2000]病