Array.prototype.slice.apply的使用方法
作者:bea
代码如下: function test(){ //将参数转为一个数组 var args = Array.prototype.slice.apply(arguments); alert(args); } arguments在JavaScript语法中是函数特有的一个对象属性(Arguments对象),用来引用调用该函数时传递的实际参数。这个对象很象数组,拥有length属性且使用下标的形式来获取其元素,但它又并非真正的Array对象。更多关于A
代码如下:
function test(){
//将参数转为一个数组
var args = Array.prototype.slice.apply(arguments);
alert(args);
}
arguments在JavaScript语法中是函数特有的一个对象属性(Arguments对象),用来引用调用该函数时传递的实际参数。这个对象很象数组,拥有length属性且使用下标的形式来获取其元素,但它又并非真正的Array对象。更多关于Arguments对象的资料请参阅《JavaScript权威指南》。
所以,直接调用arguments.slice()将返回一个"Object doesn't support this property or method"错误,因为arguments不是一个真正的数组。而以上代码调用Array.prototype.slice.apply(arguments)的意义就在于它能将函数的参数对象转化为一个真正的数组。JavaScript脚本引擎如何实现我们不得而知,但这种方式确实是有效的,而且在主流浏览器上都测试通过。另一方面也可推知Arguments对象和Array对象的亲缘关系。如果你在编写JavaScript的时候,常常碰到需要将arguments对象转成Array来处理的情形,这个技巧可以帮上忙。
这个技巧来自鼎鼎大名的DouglasCrockford。推而广之,Array其他的原型方法也可以应用在arguments上,比如:
var arg0 = Array.prototype.shift.apply(arguments);
shift也是Array的一个实例方法,用于获取并返回数组的第一个元素。当然如上的调用虽然可执行,但却纯属多余,不如直接调用arguments[0]来的简单直接。再推而广之,我们也可以对很多形似Array的Collection对象应用这个技巧,比如Array.prototype.slice.apply(document.getElementsByTagName('div')); 不过很遗憾,IE并不支持这样的调用,Firefox和Opera则都能得到正确的结果。
Prototype1.4中增加的$A()方法也常用来将arguments转为数组,我们看它的实现:
代码如下:
var $A = Array.from = function(iterable) {
if(!iterable) return[];
if(iterable.toArray) {
returniterable.toArray();
} else {
varresults = [];
for(vari=0; i<iterable.length; i++)
results.push(iterable[i]);
returnresults;
}
}
Prototype用一个for循环来构造新数组,这样是为了保证最大限度的兼容性。
有用 | 无用
猜你喜欢
您可能感兴趣的文章:
- jQuery 前的按键判断代码
- Javascript 匿名函数及其代码模式原理
- JS 有名函数表达式全面解析
- Jquery Ajax学习实例6 向WebService发出请求,返回DataSet(XML) 异步调用
- JavaScript 高效运行代码分析
- JS setCapture 区域外事件捕捉
- javascript 实现滚动效果代码整理
- JavaScript 无缝上下左右滚动加定高定宽停顿效果(兼容ie/ff)
- 小议Javascript中的this指针
- js实现的类marquee水平循环滚动
- js 把字符串当函数执行的方法
- jQuery each()方法的使用方法
- jQuery each()小议
- jquery ajax执行后台方法
- jQuery中与toggleClass等价的程序段 以及未来学习的方向
- javascript 验证日期的函数
- 12个非常有创意的JavaScript小游戏
- JQuery 插件模板 制作jquery插件的朋友可以参考下
- jquery 简单图片导航插件jquery.imgNav.js