JavaScript中call()与apply()的区别
2016-07-16 00:00
295 查看
摘要: JavaScript中call()与apply()到底有什么区别呢?请看下文
JavaScript函数,事实上是对象,他们均有两个亲儿子(非继承而来的方法),它们就是call()和apply()。
call()和apply()在函数中扮演者什么样的角色呢?
它们俩其实是一对双胞胎,功能是一样一样的,都是在特定的作用域中调用函数,就等于设置函数体中this对象的值。但是,双胞胎也并不是一模一样的,它们也有各自的性格特点嘛。
call()可以传多个参数,第一个参数是一个对象,后面的参数就是该函数的参数。
apply()最多只能传两个参数,第一个参数是一个对象,第二个参数是该函数参数组成的数组,也可以是arguments对象。
举个栗子:
JavaScript函数,事实上是对象,他们均有两个亲儿子(非继承而来的方法),它们就是call()和apply()。
call()和apply()在函数中扮演者什么样的角色呢?
它们俩其实是一对双胞胎,功能是一样一样的,都是在特定的作用域中调用函数,就等于设置函数体中this对象的值。但是,双胞胎也并不是一模一样的,它们也有各自的性格特点嘛。
call()可以传多个参数,第一个参数是一个对象,后面的参数就是该函数的参数。
apply()最多只能传两个参数,第一个参数是一个对象,第二个参数是该函数参数组成的数组,也可以是arguments对象。
举个栗子:
var age = 0; var zhangsan= { name: "张三", age: 18 }; function getAge(){ return this.age; } function add(a,b){ this.age = a+b; return a+b; } console.log(getAge()); // 0 console.log(getAge.call(zhangsan)); // 18 console.log(add.apply(zhangsan,[2,3])); // 5
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 最后一次说说闭包
- Ajax
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 对一个分号引发的错误研究
- 异步流程控制:7 行代码学会 co 模块
- ES6 走马观花(ECMAScript2015 新特性)
- JavaScript拆分字符串时产生空字符的原因
- Canvas 在高清屏下绘制图片变模糊的解决方法
- Redux系列02:一个炒鸡简单的react+redux例子
- JavaScript 各种遍历方式详解