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 相关文章推荐
javascript parseInt 大改造
Sep 27 Javascript
Javascript面向对象编程(二) 构造函数的继承
Aug 28 Javascript
js 判断计算字符串长度/判断空的简单方法
Aug 05 Javascript
js获取对象为null的解决方法
Nov 21 Javascript
node.js中的fs.realpath方法使用说明
Dec 16 Javascript
BootStrap学习笔记之nav导航栏和面包屑导航
Jan 03 Javascript
vue.js 初体验之Chrome 插件开发实录
May 13 Javascript
JavaScript hasOwnProperty() 函数实例详解
Aug 04 Javascript
webpack@v4升级踩坑(小结)
Oct 08 Javascript
Vue2.0+Vux搭建一个完整的移动webApp项目的示例
Mar 19 Javascript
webpack4 从零学习常用配置(小结)
May 28 Javascript
如何使用vue slot创建一个模态框的实例代码
May 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
浅析PHP中Collection 类的设计
2013/06/21 PHP
详解PHP中的序列化、反序列化操作
2017/03/21 PHP
PHP实现获取url地址中顶级域名的方法示例
2019/06/05 PHP
用Javascript读取中文COOKIE的解决办法
2007/02/15 Javascript
JavaScript constructor和instanceof,JSOO中的一对欢喜冤家
2009/05/25 Javascript
jQuery中获取Radio元素值的方法
2013/07/02 Javascript
jquery淡化版banner异步图片文字效果切换图片特效
2014/04/08 Javascript
Javascript核心读书有感之语句
2015/02/11 Javascript
JavaScript包装对象使用详解
2015/07/09 Javascript
AngularJS基础 ng-href 指令用法
2016/08/01 Javascript
jQuery dataTables与jQuery UI 对话框dialog的使用教程
2016/09/02 Javascript
three.js实现围绕某物体旋转
2017/01/25 Javascript
Linux CentOS系统下安装node.js与express的方法
2017/04/01 Javascript
垃圾回收器的相关知识点总结
2018/05/13 Javascript
jquery获取select选中值的文本,并赋值给另一个输入框的方法
2018/08/21 jQuery
详解小程序不同页面之间通讯的解决方案
2018/11/23 Javascript
[00:09]DOTA2全国高校联赛 精彩活动引爆全场
2018/05/30 DOTA
爬山算法简介和Python实现实例
2014/04/26 Python
实例讲解Python中global语句下全局变量的值的修改
2016/06/16 Python
PyQt5打开文件对话框QFileDialog实例代码
2018/02/07 Python
基于python批量处理dat文件及科学计算方法详解
2018/05/08 Python
opencv 获取rtsp流媒体视频的实现方法
2019/08/23 Python
django使用xadmin的全局配置详解
2019/11/15 Python
解决pycharm 安装numpy失败的问题
2019/12/05 Python
Python安装与卸载流程详细步骤(图解)
2020/02/20 Python
Python实现清理微信僵尸粉功能示例【基于itchat模块】
2020/05/29 Python
AT&T Wireless:手机、无限数据计划和配件
2018/06/03 全球购物
美国在线宠物商店:Chewy
2019/01/12 全球购物
网站编辑求职信
2013/10/17 职场文书
廉洁使者实施方案
2014/03/29 职场文书
幼儿园六一活动总结
2014/08/27 职场文书
小学教师个人总结
2015/02/05 职场文书
PHP使用非对称加密算法RSA
2021/04/21 PHP
自制短波长线天线频率预选器 - 成功消除B2K之流的镜像
2021/04/22 无线电
MySQL多表查询机制
2022/03/17 MySQL
《异世界四重奏》剧场版6月10日上映 PV视觉图原创角色发表
2022/03/20 日漫