您的位置:首页 > 移动开发

javascript(js)中函数apply和call的用法、区别、联系

2016-05-25 08:55 579 查看
js中apply和call两种方法作用基本是一样的,主要的功能有两个:

1. 改变函数作用域

2. 借用其他函数的功能

基本的用法为

functionName.apply(作用域, 数组形式参数列表) 和functionName.apply(作用域, 参数列表)

a.apply(obj, [1, 2])  a.call(obj, 1, 2);

举例说明:

1. 改变函数作用域

比如有两个对象

var a = {

name: 'a',

sayName: function(){

alert(this.name);

}

}

a.sayName(); //弹出a

var b = {
name: 'b',
sayName: function(){
alert(this.name);
}

}

b.sayName(); //弹出b

见证奇迹的时刻到啦

a.sayName.apply(b); //弹出b

a.sayName.call(b); //弹出b

这个函数的意思是,将对象a中的sayName函数的作用于变为b对象,然后执行sayName这个函数

在这里apply和call功能是一样的

2. 借用其他函数的功能

这个功能以求几个数中最大数为例说明

在js中求几个数中最大值的方法为:

var max = Math.max(1, 2, 10, 7); //结果为10

假如我想求一个数组中的最大怎么办呢?这时apply就派上用场了

Math.max.apply('', [1, 2, 10, 7]); //结果为10

这里只能使用apply,不能用call,它们的主要区别是apply接受的参数要以数组的形式给出,

而call是要把参数一一列举出来。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息