JS里的call()方法和apply()方法

一.每个函数都有两个非继承而来的方法,call()方法和apply()方法;

二.作用:这两个方法的作用是一样的,都是在特定的作用域中调用函数,等于设置函数体内this对象的值,以扩充函数赖以运行的作用域。

一般来说,this总是指向调用某个方法的对象,但是使用call()和apply()方法时,就会改变this的指向。

1:有关call()方法

语法:call(thisObj,arg1,arg2,...,argN);

参数:thisObj,可选项,将被用作当前对象的对象(即this的指向),若该选项没写,则指向全局对象;

参数:arg1,arg2,...,argNj,可选项,这些是要调用的方法的参数

 
//例子1:对于thisObj的应用
window.color = "aaa";
document.color = "bbb";
var say = {
    color: "ccc"
};
function changeColor () {
    console.log(this.color);
}
changeColor();  //aaa  (这里默认的this指针指向了全局对象window)
changeColor.call(window);    //aaa  (这里将this指针指向了window)
changeColor.call(document);  //bbb  (这里将this指针指向了document)
changeColor.call(say);       //ccc  (这里将this指针指向了say)
//例子2:对于参数thisObjargN的应用
var getWord = {
    words : "周一",
    speak : function (name) {
        console.log(name + "!" +this.words);
    }
};
getWord.speak("今天");  //今天!周一
var otherWord = {
    words : "周二"
};
getWord.speak.call(otherWord,"明天");  //明天!周二

2:有关apply()方法

语法:apply([thisObj [,argArray] ]);

接收两个参数,一个是函数运行的作用域(this),另一个是参数数组。

说明:如果argArray不是一个有效数组或不是arguments对象,那么将导致一个 TypeError;

如果没有提供argArray和thisObj任何一个参数,那么Global对象将用作thisObj。

//例子1window.color = "aaa";
document.color = "bbb";
var say = {
    color: "ccc"
};
function changeColor () {
    console.log(this.color);
}
changeColor();  //aaa  (这里默认的this指针指向了全局对象window)
changeColor.apply(window);    //aaa  (这里将this指针指向了window)
changeColor.apply(document);  //bbb  (这里将this指针指向了document)
changeColor.apply(say);

3. 不同点:接收参数的方式不同。

call()方法  :第一个参数和apply()方法的一样,但是传递给函数的参数必须列举出来


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值