javascript arguments使用示例


Posted in Javascript onDecember 16, 2014
<script Language="JavaScript">

//第一个参数值. 

function test(a,b,c,d){ 

  alert(arguments[0]); 

} 

//arguments[0]实际上就是a,同理,arguments[1]就是b,依次c,d

</script>

 
 <script Language="JavaScript">

{

    function function_Name(exp1,exp2,exp3,exp4)

    {

        var umber="";

        umber=arguments.length;

        alert(umber);

    }

            function_Name('a','b','c','d');         都可以调用

        //    function_Name("a","b","c","d");     都可以调用

}

</script>

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

 Array.prototype.testArg = "test";

 function funcArg() {

     alert(funcArg.arguments.testArg);  

     alert(funcArg.arguments[0]);

 }

 alert(new Array().testArg); // result: "test"

 funcArg(10);                // result: "undefined"  "10"

2、arguments对象的长度是由实参个数而不是形参个数决定的。形参是函数内部重新开辟内存空间存储的变量,但是其与arguments对象内存空间并不重叠。对于arguments和值都存在的情况下,两者值是同步的,但是针对其中一个无值的情况下,对于此无值的情形值不会得以同步。如下代码可以得以验证。

 function f(a, b, c){

     alert(arguments.length);   // result: "2"

     a = 100;

     alert(arguments[0]);       // result: "100"

     arguments[0] = "qqyumidi";

     alert(a);                  // result: "qqyumidi"

     alert(c);                  // result: "undefined"

     c = 2012;

     alert(arguments[2]);       // result: "undefined"

 }

 f(1, 2);

3、由JavaScript中函数的声明和调用特性,可以看出JavaScript中函数是不能重载的。

根据其他语言中重载的依据:"函数返回值不同或形参个数不同",我们可以得出上述结论:

第一:Javascript函数的声明是没有返回值类型这一说法的;

第二:JavaScript中形参的个数严格意义上来讲只是为了方便在函数中的变量操作,实际上实参已经存储在arguments对象中了。

另外,从JavaScript函数本身深入理解为什么JavaScript中函数是不能重载的:在JavaScript中,函数其实也是对象,函数名是关于函数的引用,或者说函数名本身就是变量。对于如下所示的函数声明与函数表达式,其实含以上是一样的(在不考虑函数声明与函数表达式区别的前提下),非常有利于我们理解JavaScript中函数是不能重载的这一特性。

 function f(a){

     return a + 10;

 }

 function f(a){

     return a - 10;

 }

 // 在不考虑函数声明与函数表达式区别的前提下,其等价于如下

 var f = function(a){

     return a + 10;

 }

 var f = function(a){

     return a - 10;

 }

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

如下:

 function count(a){

     if(a==1){

         return 1;

     } 

     return a + arguments.callee(--a);

 }

 var mm = count(10);

 alert(mm);
Javascript 相关文章推荐
Javascript 类与静态类的实现
Apr 01 Javascript
JS中的substring和substr函数的区别说明
May 07 Javascript
图片上传判断及预览脚本的效果实例
Aug 07 Javascript
JS实现的左侧竖向滑动菜单效果代码
Oct 19 Javascript
以jQuery中$.Deferred对象为例讲解promise对象是如何处理异步问题
Nov 13 Javascript
angularjs 中$apply,$digest,$watch详解
Oct 13 Javascript
jQuery日期范围选择器附源码下载
May 23 jQuery
Angular Material Icon使用详解
Nov 07 Javascript
Node.js + express实现上传大文件的方法分析【图片、文本文件】
Mar 14 Javascript
利用Bootstrap Multiselect实现下拉框多选功能
Apr 08 Javascript
微信小程序网络请求实现过程解析
Nov 06 Javascript
React生命周期原理与用法踩坑笔记
Apr 28 Javascript
javascript实现日期格式转换
Dec 16 #Javascript
javascript实现禁止复制网页内容
Dec 16 #Javascript
node.js中的fs.rmdirSync方法使用说明
Dec 16 #Javascript
node.js中的fs.rmdir方法使用说明
Dec 16 #Javascript
使用Chrome调试JavaScript的断点设置和调试技巧
Dec 16 #Javascript
node.js中的fs.fchownSync方法使用说明
Dec 16 #Javascript
node.js中的fs.fchown方法使用说明
Dec 16 #Javascript
You might like
php简单静态页生成过程
2008/03/27 PHP
基于PHP遍历数组的方法汇总分析
2013/06/08 PHP
Laravel中扩展Memcached缓存驱动实现使用阿里云OCS缓存
2015/02/10 PHP
js实时监听文本框状态的方法
2011/04/26 Javascript
javascript实现tabs选项卡切换效果(自写原生js)
2013/03/19 Javascript
js控制表单操作的常用代码小结
2013/08/15 Javascript
js 走马灯简单实例
2013/11/21 Javascript
解决用jquery load加载页面到div时,不执行页面js的问题
2014/02/22 Javascript
JavaScript onkeypress事件入门实例(按下或按住一个键盘按键)
2014/10/17 Javascript
JavaScript实现计算字符串中出现次数最多的字符和出现的次数
2015/03/12 Javascript
基于jQuery 实现bootstrapValidator下的全局验证
2015/12/07 Javascript
APP中javascript+css3实现下拉刷新效果
2016/01/27 Javascript
AngularJS自动表单验证
2016/02/01 Javascript
js控制div层的叠加简单方法
2016/10/15 Javascript
yarn与npm的命令行小结
2016/10/20 Javascript
纯js仿淘宝京东商品放大镜功能
2017/03/02 Javascript
详解vue-cli快速构建vue应用并实现webpack打包
2017/12/13 Javascript
JavaScript实现封闭区域布尔运算的示例代码
2018/06/25 Javascript
vue3.0 CLI - 2.2 - 组件 home.vue 的初步改造
2018/09/14 Javascript
vue实现的组件兄弟间通信功能示例
2018/12/04 Javascript
实用的Vue开发技巧
2019/05/30 Javascript
Vue 数据绑定的原理分析
2020/11/16 Javascript
python遍历文件夹下所有excel文件
2018/01/03 Python
对python 各种删除文件失败的处理方式分享
2018/04/24 Python
python opencv把一张图片嵌入(叠加)到另一张图片上的实现代码
2020/06/11 Python
Django框架安装及项目创建过程解析
2020/09/14 Python
如何使用html5与css3完成google涂鸦动画
2012/12/16 HTML / CSS
html5通过canvas实现刮刮卡效果示例分享
2014/01/27 HTML / CSS
法国一家芭蕾舞鞋公司:Repetto
2018/11/12 全球购物
国际商务专业职业生涯规划书范文
2014/01/17 职场文书
公司会计岗位职责
2014/02/13 职场文书
信息学院毕业生自荐信范文
2014/03/04 职场文书
行政管理专业求职信
2014/07/06 职场文书
社区服务活动报告
2015/02/05 职场文书
2019送给家人们的中秋节祝福语
2019/08/15 职场文书
Python中异常处理用法
2021/11/27 Python