html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

浅谈javascript中的Function和Arguments_javascript技巧_

[ ] 已经帮助:人解决问题

javascript的FunctionQ39HTML5中文学习网 - HTML5先行者学习网

属性:Q39HTML5中文学习网 - HTML5先行者学习网

1、Arguments对象Q39HTML5中文学习网 - HTML5先行者学习网

2、callerQ39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

 对调用单前函数的Function的引用,如果是顶层代码调用,Q39HTML5中文学习网 - HTML5先行者学习网
 则返回null(firefox返回undefined)。Q39HTML5中文学习网 - HTML5先行者学习网
 注:只有在代码执行时才有意义Q39HTML5中文学习网 - HTML5先行者学习网

3、lengthQ39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

 声明函数是指定的命名参数的个数(函数定义是,定义参数的个数)Q39HTML5中文学习网 - HTML5先行者学习网

4、prototypeQ39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

 一个对象,用于构造函数,这个对象定义的属性和方法Q39HTML5中文学习网 - HTML5先行者学习网
 由构造函数创建的所有对象共享。Q39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

方法:Q39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

 applay() --> applay(this,[])Q39HTML5中文学习网 - HTML5先行者学习网
 call() --> call(this,可变参数)Q39HTML5中文学习网 - HTML5先行者学习网
 toString()Q39HTML5中文学习网 - HTML5先行者学习网

javascript的Arguments对象Q39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

Arguments对象只在函数体内定义,他是一个类数组(是对象不是数组,只是有数组的一些特性)。Q39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

说明:Q39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

当一个函数被调用的时候,会为该函数创建一个Arguments对象,Q39HTML5中文学习网 - HTML5先行者学习网
局部变量arguments会自动初始化并引用那个Arguments对象(arguments是Arguments对象的引用)Q39HTML5中文学习网 - HTML5先行者学习网

该对象的属性:Q39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

1、calleeQ39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

对当前正在执行的函数的引用Q39HTML5中文学习网 - HTML5先行者学习网

2、lengthQ39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

传递给函数参数的个数(实际传递给函数参数的个数)Q39HTML5中文学习网 - HTML5先行者学习网

arguments特性Q39HTML5中文学习网 - HTML5先行者学习网

arguments对象不能显式创建,arguments对象只有函数开始时才可用。函数的 arguments 对象并不是一个数组,访问单个参数的方式与访问数组元素的方式相同。索引 n 实际上是 arguments 对象的 0…n 属性的其中一个参数。Q39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

在javascript中,不需要明确指出参数名,就能访问它们。如:Q39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

function hi(){if(arguments[0]=="andy"){   return;}alert(arguments[0]);

arguments的length属性Q39HTML5中文学习网 - HTML5先行者学习网

含义Q39HTML5中文学习网 - HTML5先行者学习网

返回调用程序传递给函数的实际参数数目。Q39HTML5中文学习网 - HTML5先行者学习网

用法Q39HTML5中文学习网 - HTML5先行者学习网

[function.]arguments.lengthQ39HTML5中文学习网 - HTML5先行者学习网

其中可选项 function 参数是当前正在执行的 Function 对象的名称。Q39HTML5中文学习网 - HTML5先行者学习网

说明Q39HTML5中文学习网 - HTML5先行者学习网

当 Function 对象开始执行时,脚本引擎将 arguments 对象的 length 属性初始化为传递给该函数的实际参数数目。Q39HTML5中文学习网 - HTML5先行者学习网

js不会主动为你判断你到底给函数传了多少个参数,如果你多传了,多余的部分就没有被使用,如果你少传了,那么没传的参数值就是undefinedQ39HTML5中文学习网 - HTML5先行者学习网

所以我们可以借助arguments的length属性来检测调用函数时是否使用了正确数目的实际参数,因为javascript是不会为你做这些事的Q39HTML5中文学习网 - HTML5先行者学习网

arguments 的 0...n 属性Q39HTML5中文学习网 - HTML5先行者学习网

含义Q39HTML5中文学习网 - HTML5先行者学习网

返回一个 arguments 对象中的各个参数的实际值,相应的值是由一个正在执行的函数的 arguments属性返回的。Q39HTML5中文学习网 - HTML5先行者学习网

用法Q39HTML5中文学习网 - HTML5先行者学习网

[function.]arguments[[0|1|2|...|n]]Q39HTML5中文学习网 - HTML5先行者学习网

参数Q39HTML5中文学习网 - HTML5先行者学习网

functionQ39HTML5中文学习网 - HTML5先行者学习网

可选项。当前正在执行的 Function 对象的名称。Q39HTML5中文学习网 - HTML5先行者学习网

0, 1, 2, …, nQ39HTML5中文学习网 - HTML5先行者学习网

必选项。0 到 n 范围内的非负整数,其中 0 代表第一个参数而 n 代表最后一个参数。最后参数 n 的值为 arguments.length-1Q39HTML5中文学习网 - HTML5先行者学习网

说明Q39HTML5中文学习网 - HTML5先行者学习网

0 . . . n 属性所返回的值就是传递给正在执行的函数的实际值。尽管实际上并不是一个参数数组,您还是可以按照与访问数组元素的方法相同的方式访问组成 arguments 对象的各个参数。Q39HTML5中文学习网 - HTML5先行者学习网

示例Q39HTML5中文学习网 - HTML5先行者学习网

下面的例子演示了 arguments 对象的 0 . . . n 属性的用法Q39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

 Q39HTML5中文学习网 - HTML5先行者学习网

function ArgTest(){  var s = "";  s += "The individual arguments are: "  for (n=0; n< arguments.length; n++){   s += ArgTest.arguments[n];   s += " ";  }  return(s);}print(ArgTest(1, 2, "hello", new Date()));

 arguments的callee属性Q39HTML5中文学习网 - HTML5先行者学习网

含义Q39HTML5中文学习网 - HTML5先行者学习网

表示对函数对象本身的引用,也就是所指定的 Function 对象的正文,这有利于实现无名函数的递归或者保证函数的封装性。Q39HTML5中文学习网 - HTML5先行者学习网

用法Q39HTML5中文学习网 - HTML5先行者学习网

[function.]arguments.calleeQ39HTML5中文学习网 - HTML5先行者学习网

可选项 function 参数是当前正在执行的 Function 对象的名称。Q39HTML5中文学习网 - HTML5先行者学习网

说明Q39HTML5中文学习网 - HTML5先行者学习网
callee 属性是 arguments 对象的一个成员,仅当相关函数正在执行时才可用。Q39HTML5中文学习网 - HTML5先行者学习网

callee 属性的初始值就是正被执行的 Function 对象。这允许匿名的递归函数。Q39HTML5中文学习网 - HTML5先行者学习网

实例:Q39HTML5中文学习网 - HTML5先行者学习网

用递归来计算1到n的自然数之和:Q39HTML5中文学习网 - HTML5先行者学习网
Q39HTML5中文学习网 - HTML5先行者学习网

 Q39HTML5中文学习网 - HTML5先行者学习网

<script>   var sum=function(n){   if(1==n) {    return 1;   } else {    return n + arguments.callee(n-1);   }  }  alert(sum(100));</script>

对函数Function原型prototype的一下说明:Q39HTML5中文学习网 - HTML5先行者学习网

当通过构造函数初始化一个对象的时候,Q39HTML5中文学习网 - HTML5先行者学习网

new关键字通过调用构造函数初始化这个对象,并把新的对象 作为this关键字的值 来传递,Q39HTML5中文学习网 - HTML5先行者学习网

与此同时,new关键字还设置了这个对象的原型,一个对象的原型就是它的构造函数的prototype属性的值Q39HTML5中文学习网 - HTML5先行者学习网

(例如:a = new Date(),a对象的原型就是Date.prototype)Q39HTML5中文学习网 - HTML5先行者学习网

所有的函数都有一个prototype属性,当这个函数【被定义】的时候,prototype属性会自动创建和初始化。Q39HTML5中文学习网 - HTML5先行者学习网

prototype属性的初始化值是一个对象,并且这个对象只有一个属性,这个属性是constructor,Q39HTML5中文学习网 - HTML5先行者学习网

它指回到和原型相关联的那个构造函数。Q39HTML5中文学习网 - HTML5先行者学习网

以上这篇浅谈javascript中的Function和Arguments就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。Q39HTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助