call()与apply()简单介绍

call 和 apply 都是为了动态改变某个函数运行时的上下文而存在的,即改变函数体内部 this 的指向。call 和 apply 主要的区别在于他们的声明方式不同。call 需要参数分开传递,而 apply 需要传入由参数组成的数组。
ep:

function people() {}
 people.prototype = {
    say: function() {
      alert("hell word");
    }
}

var student = new people();
student.say(); //hello world

student2 = {};  //没有say()方法
student.say.call(student2);  //hello world
studnet.say.apply(student2);  //此时的student2可以使用say()方法

(1).传递参数
ep:

function sum(x,y) {
    return x+y;
}
function call1(num1,num2) {
    return sum.call(this,num1,num2);
}
function apply1(num1,num2) {
    return sum.apply(this,[num1,num2]);  //参数为数组形式
}

(2).改变函数运行的作用域

window.color = 'red';
var obj = {color: 'blue'};
function showColor() {
    alert(this.color);  
}
showColor.call(this);  //red
showColor.call(obj);  //blue
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值