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是要把参数一一列举出来。
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是要把参数一一列举出来。
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- easyui------显示隐藏列功能
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子