详解 JavaScript的 call() 和 apply()
来源:互联网 发布:专业电气制图软件 编辑:程序博客网 时间:2024/04/28 18:31
定义
ECMAScript规范为所有函数都包含两个方法(这两个方法非继承而来), call
和 apply
。这两个函数都是在特定的作用域中调用函数,能改变函数的作用域,实际上是改变函数体内 this
的值 。
call 和 apply
用法
调用函数,传递参数
//定义一个add 方法 function add(x, y) { return x + y; } //用call 来调用 add 方法 function myAddCall(x, y) { //调用 add 方法 的 call 方法 return add.call(this, x, y); } //apply 来调用 add 方法 function myAddApply(x, y) { //调用 add 方法 的 applly 方法 return add.apply(this, [x, y]); } console.log(myAddCall(10, 20)); //输出结果30 console.log(myAddApply(20, 20)); //输出结果40
我们看到通过方法本身的call
和 apply
执行了该函数。
改变函数作用域
var name = '小白'; var obj = {name:'小红'}; function sayName() { return this.name; } console.log(sayName.call(this)); //输出小白 console.log(sayName. call(obj)); //输入小红
我们改变了函数运行的作用域, 通过绑定不同的对象,函数内部 this
也不同。最终输入结果才会这样。
高级用法,实现 js 继承
//父类 Person function Person() { this.sayName = function() { return this.name; } } //子类 Chinese function Chinese(name) { //借助 call 实现继承 Person.call(this); this.name = name; this.ch = function() { alert('我是中国人'); } } //子类 America function America(name) { //借助 call 实现继承 Person.call(this); this.name = name; this.am = function() { alert('我是美国人'); } } //测试 var chinese = new Chinese('成龙'); //调用 父类方法 console.log(chinese.sayName()); //输出 成龙 var america = new America('America'); //调用 父类方法 console.log(america.sayName()); //输出 America
区别
- 参数不同, apply 传入的是一个参数数组,也就是将多个参数组合成一个参数数组, call 从第二个参数开始依次传入.
- apply 可以直接将当前函数的arguments对象作为apply的第二个参数传入
结束语
call
和 apply
最大的好处:方便我们解耦,对象不需要和方法有任何的耦合性,能使我们写出更好的面相对象程序。
大家如果看一些 js 框架底层的话会看到好多地方都有大量用到。
阅读全文
0 0
- 详解 JavaScript的 call() 和 apply()
- 详解 JavaScript的 call() 和 apply()
- javascript的call()和apply()
- javascript的call和apply
- Javascript中call和apply的区别与详解
- javascript对象详解以及call、apply和bind的使用
- javascript中call()和apply()的用法及区别详解
- javascript中call()和apply()的用法及区别详解
- Javascript中call和apply的区别与详解
- Javascript中call和apply的区别与详解
- Javascript中call和apply的区别与详解
- Javascript中call和apply的区别与详解
- Javascript中call和apply的区别与详解
- Javascript中call和apply的区别与详解
- javascript apply call详解
- javascript call和apply方法详解
- javascript 中的apply()和call()方法详解
- JavaScript中的apply和call函数详解
- HDU2057(__int64 与long long 的区别)
- LINUX C++实现简单的http get请求客户机
- JUnit4-FailOnTimeout.java的源代码 解读与分析
- 关于R语言中的merge和cbind功能的用法
- OHUI V52.0 Demo
- 详解 JavaScript的 call() 和 apply()
- Jsp的四大作用域与九大对象
- Ternary Operator (?:) Java 中的三元运算
- ubantu linux下制作win10启动盘
- UVA Live 7957 (Gym 101201F) Illumination 2-SAT
- 单链表的操作练习
- HTTPS 是如何保证安全的?
- html中如何去掉浏览器右边的滚动条
- Hdu 5402 Travelling Salesman Problem 棋盘黑白染色