js function call,apply,bind方法
2015-06-22 19:45
771 查看
apply,call的作用就是在特定的作用域中调用函数。
apply接收两个参数,一个是在其中运行函数的作用域,另一个是参数数组,其中第二个参数可以是Array的实例,也可以是arguments对象,例如:
call方法与apply的区别在于它们接收参数得方式不同,对于call方法,第一个参数是this,变化的是其余参数都直接传递给函数,也就是说传递给函数的参数必须逐个列举出,例如:
bind方法会创建一个函数的实例,其this值会指向传给bind方法的对象。
以上内容均参考《javascript高级程序设计》Function类型章节。
apply接收两个参数,一个是在其中运行函数的作用域,另一个是参数数组,其中第二个参数可以是Array的实例,也可以是arguments对象,例如:
function sum (num1,num2) { return num1+num2; } function callSum1(sum1,sum2) { return sum.apply(this,arguments); //this对象指定当前函数执行环境为callSum1,因此,此处将this换为callSum1也一样 } function callSum2(sum1,sum2) { return sum.apply(this,[sum1,sum2]); } console.log(callSum1(10,10)); //20 console.log(callSum2(10,10)); //20
call方法与apply的区别在于它们接收参数得方式不同,对于call方法,第一个参数是this,变化的是其余参数都直接传递给函数,也就是说传递给函数的参数必须逐个列举出,例如:
function sum (num1,num2) { return num1+num2; } function callSum1(sum1,sum2) { return sum.call(this,sum1,sum2); } console.log(callSum1(10,10)); //20
bind方法会创建一个函数的实例,其this值会指向传给bind方法的对象。
var color = "red"; var o = {color:"blue"}; function sayColor() { console.log(this.color); } var objectSayColor = sayColor.bind(o); objectSayColor();
以上内容均参考《javascript高级程序设计》Function类型章节。
相关文章推荐
- JQuery1——基础($对象,选择器,对象转换)
- Android学习笔记(二九):嵌入浏览器
- Android java 与 javascript互访(相互调用)的方法例子
- JavaScript演示排序算法
- javascript实现10进制转为N进制数
- 2019年开发人员应该学习的8个JavaScript框架
- HTML中的script标签研究
- 异步流程控制:7 行代码学会 co 模块
- JavaScript拆分字符串时产生空字符的原因
- IE8开发人员工具教程(二)
- 在flex中执行一个javascript方法的简单方式
- Flex结合JavaScript读取本地路径的方法
- PowerShell中执行Javascript的方法示例
- javascript asp教程第六课-- response方法
- javascript asp教程More About Recordsets
- javascript asp教程第十二课---session对象
- javascript asp教程创建数据库连接
- javascript asp教程错误处理
- javascript asp教程第十课--global asa