资讯专栏INFORMATION COLUMN

JS隐藏函数 arguments的用法

Scliang / 1546人阅读

摘要:本文是本渣在看了中函数的用法之后,写的一些东西,希望能帮助到大家。同时的用法和数组有点类似,和一样,表示第一个对象。返回此对象所在的当前函数引用。在使用函数递归调用时推荐使用代替函数名本身。

本文是本渣在看了JS中函数arguments的用法之后,写的一些东西,希望能帮助到大家。

1.arguments对象

在JavaScript中,arguments对象是比较特别的一个对象,实际上是当前函数的一个内置属性。arguments非常类似Array,但实际上又不是一个Array实例。可以通过如下代码得以证实(当然,实际上,在函数funcArg中,调用arguments是不必要写成funcArg.arguments,直接写arguments即可,此处为了让大家看明白)。

Array.prototype.testArg = "shuzu";
function funcArg() {
    alert(funcArg.arguments.testArg);  
    alert(funcArg.arguments[0]);
}

alert(new Array().testArg); // result: "shuzu"
funcArg(10);                // result: "undefined"  "10"

输出结果是 :
shuzu
undefined
10
我们可以看到arguments的类型并没有数组的testArg属性。同时arguments的用法和数组有点类似,argument[0]和array[0]一样,表示第一个对象。(ps:这里的prototype的作用是给某个对象加上某种属性,不懂的小伙伴可以去w3school看看介绍。)

2.callee

arguments对象中有一个非常有用的属性:callee。arguments.callee返回此arguments对象所在的当前函数引用。在使用函数递归调用时推荐使用arguments.callee代替函数名本身。

var fibonacci =function(n) {
    return n <2? n : arguments.callee(n -1) + arguments.callee(n -2);
}; //斐波纳挈数列求值
3.called

此属性的作用简单的说 就是返回调用该函数的函数,也就是function test1(){ test2();} 只有在test2是被test1函数调用,test2.called才有意义。如果test2是在函数顶部被调用,则test2.called返回null.
如果在字符串上下文中使用 caller属性,那么结果和 functionName.toString 一样,也就是说,显示的是函数的反编译文本,

function callerDemo() {
    if (callerDemo.caller) {
        var a= callerDemo.caller.toString();
          alert(a);
      } else {
          alert("this is a top function");
      }
}
function handleCaller() {
      callerDemo();
}
handlecaller();
callerDemo();

输出结果:

function handleCaller() {
      callerDemo();
}
this is a top function

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/78866.html

相关文章

  • 前端面经整理之JS和CSS

    摘要:作为对象原型链的终点。调用函数时,应该提供的参数没有提供,该参数等于。它可以用于引用该函数的函数体内当前正在执行的函数。 一 JS 二 CSS 一 JS ==和===的区别 ===叫做严格运算符 ==叫做相等运算符严格运算符比较时不仅仅比较数值还要比较数据类型是否一样相等运算符在比较相同类型的数据时,与严格相等运算符完全一样。 在比较不同类型的数据时,相等运算符会先将数据进行类型转换,...

    stonezhu 评论0 收藏0
  • 前端面经整理之JS和CSS

    摘要:作为对象原型链的终点。调用函数时,应该提供的参数没有提供,该参数等于。它可以用于引用该函数的函数体内当前正在执行的函数。 一 JS 二 CSS 一 JS ==和===的区别 ===叫做严格运算符 ==叫做相等运算符严格运算符比较时不仅仅比较数值还要比较数据类型是否一样相等运算符在比较相同类型的数据时,与严格相等运算符完全一样。 在比较不同类型的数据时,相等运算符会先将数据进行类型转换,...

    lvzishen 评论0 收藏0
  • 命令行神器 Click 简明笔记

    摘要:是用写的一个第三方模块,用于快速创建命令行。快速使用的使用大致有两个步骤使用装饰一个函数,使之成为命令行接口使用等装饰函数,为其添加命令行选项等。本文标题为命令行神器简明笔记本文链接为参考资料学习笔记模块 Click Click 是用 Python 写的一个第三方模块,用于快速创建命令行。我们知道,Python 内置了一个 Argparse 的标准库用于创建命令行,但使用起来有些繁琐,...

    luoyibu 评论0 收藏0
  • 谈谈javascriptFunction中那些隐藏属性/方法:caller/callee/app

    摘要:在全局环境中调用函数是不会生成此属性,因为不符合此属性的存在意义价值见上条。函数递归时用起来比用函数名调用函数更带感方法这俩方法性质一样,只是用法稍有不同,因此放在一起来介绍。 javascript的Function中有不少不那么常用,又或者用了也是知其然而不知其所以然的属性/方法,本文就来谈谈这一系列属性/方法:caller/callee/apply/call/bind。 call...

    shery 评论0 收藏0
  • 盲水印和图片隐写术

    摘要:其实隐藏文件和盲水印都属于图片隐写术。图片隐写术隐写术也是数字水印的一种应用,双方可利用隐藏在数字信号中的信息进行沟通。图片隐写术只是其中一种,有兴趣的同学可以看下面这本书。盲水印一、演示首先看 这是一张女朋友解码水印接下来我们输入一行神奇的命令:python bwm.py --action decode --origin Demo.jpg --im ../Gakki.jpg --resul...

    Tecode 评论0 收藏0

发表评论

0条评论

Scliang

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<