arguments 是是JavaScript里的一个内置对象,它很古怪,也常常被人所忽视,但其实是很重要的。全部主要的js函数库都利用了arguments对象。因此agruments对象对于javascript程序员来讲是必需熟悉的。javascript
全部的函数都有属于本身的一个arguments对象,它包括了函所要调用的参数。他不是一个数组,若是用typeof arguments,返回的是’object’。虽然咱们能够用调用数据的方法来调用arguments。好比length,还有index方法。可是数 组的push和pop对象是不适用的。html
看起来貌似argument对象使用起来十分有限,可是实际上它是一个很是有用的对象。你能够经过使用argument对象让函数可以调用数量不定 的参数。在Dean Edwards的base2库里有个格式化的函数,展现了这个灵活性。java
function format(string) { 程序员
var args = arguments; 数组
var pattern = new RegExp(“%([1-" + arguments.length + "])”, ”g”); app
return String(string).replace(pattern, function(match, index) { 函数
return args[index]; spa
}); prototype
}; code
咱们提供了一个模板字符串,你能够用”%1”到“%9”给返回值添加一个占位符。而后提供给九个其余参数插入。
format(“And the %1 want to know whose %2 you %3″, ”papers”, ”shirt”, ”wear”);
上面的代码将返回:And the papers want to know whose shirt you wear"
.
有件事情咱们须要注意下,在定义函数的时候,咱们只规定了一个参数,string。Javascript容许咱们传递任何数量的参数到一个函数里,无论怎么定义这个函数。Arguments对象对这些都是容许的。
虽然arguments对象不是一个真正的javascript数组,可是咱们仍是能够轻易的把它转换成标准的数据 ,而后进行数组操做。
var args = Array.prototype.slice.call(arguments);
那么如今这个变量args就含有一个含有函数全部参数的标准javascript数组对象。
Arguments对象容许咱们去执行全部类型的javascript方法。这边附上一个makeFunc函数的定义。这个函数容许咱们去提供一个函数引用和这个函数的全部参数。他将返回一个匿名函数去调用你规定的函数,也提供了匿名函数调用时所附带的参数。
function makeFunc() {
var args = Array.prototype.slice.call(arguments);
var func = args.shift();
return function() {
return func.apply(null, args.concat(Array.prototype.slice.call(arguments)));
};
}
第一个argument对象给makeFunc提供了你想调用的函数的引用。他是从arguments数组里移除的。而后makeFunc返回了一个匿名函数去运行规定的方法。
第一个应用的argument指向了函数调用的范围,主要是函数内部关键部分所指向的。咱们先保持这个为null。第二个arguments是一个 数组,会为这个函数转变为arguments对象。makeFunc把原始的数组值串联到arguments对象里提供给匿名函数和所调用函数的数组。
你须要输出一个模板老是相同的位置,这样就能够不用老是在每次引用模板的时候调用format函数。你可使用makeFunc的通用功能去返回能够调用format而后自动补充模板的函数。
var majorTom = makeFunc(format, ”This is Major Tom to ground control. I’m %1.”);
你能够像这样调用majorTom函数:
majorTom(“stepping through the door”);
majorTom(“floating in a most peculiar way”);
每一次你调用majorTom,它会同时调用format函数和第一个argument,已经写好的模板。那么将返回
“This is Major Tom to ground control. I’m stepping through the door.”
“This is Major Tom to ground control. I’m floating in a most peculiar way.”
你可能以为这样很酷,不过,arguments还有更多的惊喜。他还有其余有用的特性:callee方法 。Arguments.callee包括了一个函数的引用去建立一个argument对象。那么该如何使用呢?
Arguments.callee方法能让一个匿名函数很方便的指向自己。
Repeat是一个承载了一个函数引用和两个数字的函数。第一个数字是函数调用几回,第二个数字是每一个调用的间隔时间,单位是毫秒。
function repeat(fn, times, delay) {
return function() {
if(times– > 0) {
fn.apply(null, arguments);
var args = Array.prototype.slice.call(arguments);
var self = arguments.callee;
setTimeout(function(){self.apply(null,args)}, delay);
}
};
}
Repeat函数使用了arguments.callee方法从变量self去获取一个引用,指向运行原始指令的函数。这样,匿名函数就能够再次调用自己。
我有一段超级简介的函数,承载了一个字符串和执行alert方法。
function comms(s) {
alert(s);
}
然而,我想建立一个特殊的版本,经过这个版本我能够重复这个动做三次,每次间隔2秒钟。那么,咱们能够
var somethingWrong = repeat(comms, 3, 2000);
somethingWrong(“Can you hear me, major tom?”);
调用了somethingWrong函数的结果就是复这个动做三次,每次alert间隔2秒钟。
Arguments虽然不是常常用到,有点古怪,可是,它充满了惊喜,很是值得咱们去了解 。
原文地址:arguments
: A JavaScript Oddity
出处:http://www.cnblogs.com/Fskjb/archive/2011/10/27/2227111.html