JavaScript arguments.callee作用及替换方案详解


Posted in Javascript onSeptember 02, 2020

一、arguments.callee的作用:返回正被执行的 Function 对象

arguments 的主要用途是保存函数参数, 但这个对象还有一个名叫 callee 的属性,返回正被执行的 Function 对象,也就是所指定的 Function 对象的正文,这有利于匿名函数的递归或者保证函数的封装性。

请看下面这个非常经典的阶乘函数

function factorial(num){  
  if (num <=1) {     
   return 1;   
  } else {     
  return num * factorial(num-1)   
  } 
}

定义阶乘函数一般都要用到递归算法;如上面的代码所示,在函数有名字,而且名字以后也不会变的情况下,这样定义没有问题。
但问题是这个函数的执行与函数名 factorial 紧紧耦合在了一起。为了消除这种紧密耦合的现象,可以像下面这样使用

arguments.callee

function factorial(num){  
  if (num <=1) {     
   return 1;   
  } else {     
  return num * arguments.callee(num-1);
  } 
}

在这个重写后的 factorial()函数的函数体内,没有再引用函数名 factorial。这样,无论引用函数时使用的是什么名字,都可以保证正常完成递归调用。例如

function factorial(num){
      if(num <= 1){
        return 1;
      }else{
        return num * arguments.callee(num-1);
      }
    }
    var trueFactorial = factorial;
    alert(trueFactorial(5));  //120  


    factorial = function() {
      return 0;
    }        
    alert(trueFactorial(5));// 120 如果没有使用arguments.callee,将返回0

在此,变量 trueFactorial 获得了 factorial 的值,实际上是在另一个位置上保存了一个函数的指针。然后,我们又将一个简单地返回 0的函数赋值给 factorial 变量。如果像原来的 factorial() 那样不使用 arguments.callee,调用 trueFactorial()就会返回 0。可是,在解除了函数体内的代码与函数名的耦合状态之后,trueFactorial()仍然能够正常地计算阶乘;至于factorial(),它现在只是一个返回 0的函数。

二、arguments.callee的替换方案

现在已经不推荐使用arguments.callee();

原因:访问 arguments 是个很昂贵的操作,因为它是个很大的对象,每次递归调用时都需要重新创建。影响现代浏览器的性能,还会影响闭包。

不能用怎么办?

递归时用到arguments.callee()是常见的事情,比如一道面试题。接受参数n=5,不用for循环输出数组【1,2,3,4,5】,这是用递归的思路,配合arguments.callee,代码如下:

function show(n) {
  var arr = [];
  return (function () {
    arr.unshift(n);
    n--;
    if (n != 0) {
      arguments.callee();
    }
    return arr;
  })()
}
show(5)//[1,2,3,4,5]

现在arguments.callee 被弃用了。怎么办,其实很简单,给内部函数一个名字即可(当函数被调用时,它的arguments.callee对象就会指向自身,也就是一个对自己的引用。)

function show(n) {
  var arr = [];
  return (function fn() {
    arr.unshift(n);
    n--;
    if (n != 0) {
      fn();
    }
    return arr;

  })()
}
show(5)//[1,2,3,4,5]

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
动态加载jquery库的方法
Feb 12 Javascript
用原生JS获取CLASS对象(很简单实用)
Oct 15 Javascript
jQuery实现购物车数字加减效果
Mar 14 Javascript
leaflet的开发入门教程
Nov 17 Javascript
js实现移动端微信页面禁止字体放大
Feb 16 Javascript
详解vue嵌套路由-query传递参数
May 23 Javascript
强大的 Angular 表单验证功能详细介绍
May 23 Javascript
vue.js 实现评价五角星组件的实例代码
Aug 13 Javascript
解决vue单页面应用中动态修改title问题
Jun 09 Javascript
微信小程序收藏功能的实现代码
Jun 19 Javascript
vue:el-input输入时限制输入的类型操作
Aug 05 Javascript
最新最全的手机号验证正则表达式
Feb 24 Javascript
JavaScript Array.flat()函数用法解析
Sep 02 #Javascript
通过实例解析JavaScript常用排序算法
Sep 02 #Javascript
手把手教你实现 Promise的使用方法
Sep 02 #Javascript
如何基于jQuery实现五角星评分
Sep 02 #jQuery
在vscode 中设置 vue模板内容的方法
Sep 02 #Javascript
JavaScript array常用方法代码实例详解
Sep 02 #Javascript
Vue前端判断数据对象是否为空的实例
Sep 02 #Javascript
You might like
支持oicq头像的留言簿(一)
2006/10/09 PHP
PHP实现基于mysqli的Model基类完整实例
2016/04/08 PHP
php组合排序简单实现方法
2016/10/15 PHP
Laravel中10个有用的用法小结
2019/05/06 PHP
thinkPHP+LayUI 流加载实现功能
2019/09/27 PHP
Thinkphp 框架扩展之应用模式实现方法分析
2020/04/27 PHP
基于jquery的划词搜索实现(备忘)
2010/09/14 Javascript
当自定义数据属性为json格式字符串时jQuery的data api问题探讨
2013/02/18 Javascript
JS将表单导出成EXCEL的实例代码
2013/11/11 Javascript
javascript window.open打开新窗口后无法再次打开该窗口问题的解决方法
2014/04/12 Javascript
跟我学Nodejs(三)--- Node.js模块
2014/05/25 NodeJs
js绘制圆形和矩形的方法
2015/08/05 Javascript
jQuery实现简单的文件上传进度条效果
2020/03/26 Javascript
JS判断当前页面是否在微信浏览器打开的方法
2015/12/08 Javascript
PHP 实现一种多文件上传的方法
2017/09/20 Javascript
深入浅析AngularJs模版与v-bind
2018/07/06 Javascript
node Buffer缓存区常见操作示例
2019/05/04 Javascript
JavaScript实现简单计算器功能
2019/12/19 Javascript
Javascript异步编程async实现过程详解
2020/04/02 Javascript
有趣的JavaScript隐式类型转换操作实例分析
2020/05/02 Javascript
Python 25行代码实现的RSA算法详解
2018/04/10 Python
python多线程之事件Event的使用详解
2018/04/27 Python
python3中的md5加密实例
2018/05/29 Python
Python minidom模块用法示例【DOM写入和解析XML】
2019/03/25 Python
Python实现数据结构线性链表(单链表)算法示例
2019/05/04 Python
python中selenium操作下拉滚动条的几种方法汇总
2019/07/14 Python
python rsa-oaep加密的示例代码
2020/09/23 Python
html5 css3 动态气泡按钮实例演示
2012/12/02 HTML / CSS
浅谈CSS3鼠标移入图片动态提示效果(transform)
2017/11/06 HTML / CSS
Champion澳大利亚官网:美国冠军运动服装
2018/05/07 全球购物
小学班主任培训方案
2014/06/04 职场文书
行政专员岗位职责说明书
2014/07/30 职场文书
初三语文教学计划
2015/01/22 职场文书
2015年工会工作总结
2015/03/30 职场文书
圣诞晚会主持词
2015/07/01 职场文书
CSS3实现三角形不断放大效果
2021/04/13 HTML / CSS