在函数内部有两个特殊的对象,arguments 和 this,还有一个函数对象的属性caller。

arguments对象

arguments是一个类似数组的对象,包含着传入函数的所有参数。

function doAdd(){
if(arguments.length == 1){
return arguments[0] + 10;
}else if(arguments.length == 2){
return arguments[0] + arguments[1];
}
}
console.log(doAdd(11)); //
console.log(doAdd(11,20)); //

arguments对象还有一个属性callee,该属性是一个指针,指向拥有这个arguments对象的函数。

function factorial(num){

    if(num <=1){
return 1;
} else {
return num*arguments.callee(num - 1);
} }
// 消除代码和函数名的耦合。

在严格模式 ("use strict")下,访问 arguments.callee 会出错。

在严格模式下也能实现递归:

var factorial = (function f(num){

    if(num <=1){
return 1;
} else {
return num*f(num - 1);
}
});
console.log(factorial(4)); //

this对象

this引用的是函数的执行环境对象。在函数调用之前this对象的值是不确定的,在网页浏览器的全局作用域中调用函数时,this对象引用的是window:

window.color = "red";
var o ={
color : "blue"
}; function sayColor(){
alert( this.color);
}
sayColor(); // red, 在全局作用域中调用函数,this引用的是window对象 o.sayColor = sayColor;
o.sayColor(); // blue, 引用对象o

caller属性

caller属性指向调用该函数的函数,如果是在全局作用域中调用当前函数,它的值为null:

function outer(){
inner();
}
function inner(){
console.log(inner.caller);
// console.log(arguments.callee.caller);
} outer(); // 打印outer函数的源代码
inner(); //打印null

call()和apply()

每个函数都包含这两个非继承而来的函数,这两个函数的用途都是在特定的作用域中调用函数,实际上等同于在设置函数体内的this对象的值。

apply()有两个参数,第一个是运行时函数的作用域(执行环境)对象,第二个是参数对象,可以是arguments对象,或者是数组

call()函数的第一个参数也是作用域对象,其余参数是传递给函数的参数,需要逐个列出来

apply()和call()最常用的场景是改变函数运行的作用域。这样对象就可以不需要和方法有任何耦合的关系

var color = "red";
var o = {"color":"blue"};
function sum(num1,num2){
console.log(this.color);
return num1+num2;
}
function callSum1(num1,num2){
return sum.apply(this, arguments);
}
function callSum2(num1,num2){
return sum.apply(this, [num1,num2]);
} function callSum3(num1,num2){
return sum.call(this, num1,num2);
} o.callSum1 = callSum1;
o.callSum2 = callSum2; console.log(callSum1(10,10)); // red 20
console.log(callSum2(10,10)); // red 20
console.log(callSum1.apply(o,[10,10])); // blue 20
console.log(callSum3.call(o,10,10)); // blue 20,直接改变作用域
console.log(o.callSum1(5,10)); // blue 15
console.log(o.callSum2(5,10)); // blue 15

 bind()

bind()函数会创建一个函数实例,新的函数的this值为被绑定为传给bind()函数的值

var color = "red";
var o = {"color":"blue"}; function sayColor(){
console.log(this.color);
}
var objectSayColor = sayColor.bind(o);
objectSayColor(); // blue, 即使在全局中调用,this值仍为对象o

js中函数的 this、arguments 、caller,call(),apply(),bind()的更多相关文章

  1. JS中函数参数和函数返回值的理解

    函数本质就是功能的集合 JS中函数是对象,因此,函数名实际上仅仅是一个指向函数对象的指针,不会与某个函数绑定,所以,JS中没有重载(重载就是通过传递不同类型的参数,使两个相同函数名的函数执行不同的功能 ...

  2. js中函数传参的情况

    <!DOCTYPE html><html lang="en"><head> <meta charset="UTF-8" ...

  3. 对JS中函数的理解

    函数本质就是功能的集合 JS中函数是对象,因此,函数名实际上仅仅是一个指向函数对象的指针,不会与某个函数绑定,所以,JS中没有重载(重载就是通过传递不同类型的参数,使两个相同函数名的函数执行不同的功能 ...

  4. 关于js中函数的调用问题

    js中函数的调用方法 1.直接调用 函数名(参数): 2.通过指向函数的变量去调用 例如: var myval = 函数名: 此刻 myval是指向函数的一个指针: myval(实际参数):此刻调用的 ...

  5. JS中函数void()

    <a href="javascript:void(0)">hello</a>/* * JS中函数void()的运用大体是这种新式; * void()是运算符 ...

  6. js中函数的参数为函数的情况即回调函数

    js中函数的参数可以是数组对象也可以是函数,当参数为函数时我们叫做回调函数 //定义回调函数function B() { console.log("函数B")setTimeout( ...

  7. JS中函数的调用和this的值

    调用每一个函数会暂停当前函数的执行,传递控制权和参数给新函数.除了声明时定义的形式参数,每个函数还接收两个附加的参数:this 和 arguments. 参数this在面向对象编程中非常重要,他的值取 ...

  8. js 中arguments,call,apply,bind的使用

    //对于 arguments和this, 每个函数都有自己独有的arguments和this, 且不进行链式查找 //arguments是什么? //答:1:arguments是收到的实参副本 //2 ...

  9. js中函数this的指向

    this 在面试中,js指向也常常被问到,在开发过程中也是一个需要注意的问题,严格模式下的this指向undefined,这里就不讨论. 普通函数 记住一句话哪个对象调用函数,该函数的this就指向该 ...

随机推荐

  1. 禁用firefox 56自动更新

    firefox 56支持旧式扩展,这很重要! 它却自动更新,简单地关了也不行,很是牛氓! ========== -备份C:\Users\用户名\AppData\Roaming\Mozilla\Fire ...

  2. 文件查重工具 ultraCompare 和 UltraFinder 用法

    UltraCompare 是一款文件内容比较工具,它可以对于文本.文件夹.二进制进行比较.可进行文本模式,文件夹模式以及二进制模式的比较,可对比较的文件.文件夹等进行合并,同步等操作.是进行比较操作的 ...

  3. Ruby学习笔记3:Rendering(渲染)和 Redirect(重定向)

    1. Rendering Rendering 是特别要告诉Controller 中的methods,要哪个view file来显示给用户.We can show Views as we wish! E ...

  4. iOS跳转洁面时隐藏tabBar的方法

    //1.设置self.tabBarController.tabBar.hidden=YES;       self.tabBarController.tabBar.hidden=YES;   //2. ...

  5. mezzanine的page_menu tag

    mezzanine的head 导航条.左侧tree.footer是由page_menu产生的.page_menu的算法,先计算出每一页的孩子,然后再逐页去page_menu. @register.re ...

  6. python3.6.2(32位)的安装-1

    简介:Python不需要编译成机器代码,是解释执行.解释器是机器指令,CPU执行解释器,解释器执行代码. 1.Python官网下载地址:https://www.python.org/,选择Downlo ...

  7. spring cloud之路(1)

    1.各个功能 springcloud 注册中心 Eureka负载均衡 Ribbon路由网关 Zuul断路器 Hystrix分布式配置 config服务调用跟踪 sleuth日志输出 elk 认证集成 ...

  8. SPring cloud (3)A Ribbon 负载均衡 配置初步

    1.引用pom <dependency> <groupId>org.springframework.cloud</groupId> <artifactId&g ...

  9. 【JEECG技术文档】表单配置-树形表单

    表单配置支持树型表单了,具体效果如下图: 配置说明: 1.是否树:选择是. 2.树形表单父Id:表的自关联外键. 3.树形表单列表:显示树形图标的列,如上图中为[组织机构名称]. 4.默认值:最外层数 ...

  10. APP-8-文本语音

    1.百度语音合成JS文件 baidu_tts_cors.js /** * 浏览器调用语音合成接口 * @param {Object} param 百度语音合成接口参数 * 请参考 https://ai ...