• 技术文章 >web前端 >js教程

    Array.prototype.slice.apply的使用方法_javascript技巧

    2016-05-16 18:32:08原创920
    复制代码 代码如下:

    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  results.push(iterable[i]); 
      returnresults; 
     } 
    }

    Prototype用一个for循环来构造新数组,这样是为了保证最大限度的兼容性。
    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:Array prototype slice apply
    上一篇:js实现的日期操作类DateTime函数代码_javascript技巧 下一篇:js 翻转颜色实现代码_javascript技巧
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• JavaScript中window对象常用方法总结• 一起聊聊JavaScript与HTML之间有什么区别与关联• DOM文档对象模型的简单介绍• 实例详解之操作单个dom元素添加动画• 整理JavaScript中cookie操作对象的应用
    1/1

    PHP中文网