網上不少複製粘帖說:Array.prototype.slice.call(arguments)能將具備length屬性的對象 轉成數組,除了IE下的節點集合(由於ie下的dom對象是以com對象的形式實現的,js對象與com對象不能進行轉換)數組
//使用prototype只是由於Array是構造函數 Array.prototype.slice.call([1,2,3,4,5],0)// [1, 2, 3, 4, 5] [].slice.call([1,2,3,4,5],1)// [2, 3, 4, 5] //沒有length的對象 var a={length:2, 0:'first', 1:'second'}; Array.prototype.slice.call(a);// ["first", "second"] var a={length:2, 0:'first', 1:'second'}; Array.prototype.slice.call(a,1);// ["second"] var a={0:'first', 1:'second'}; Array.prototype.slice.call(a,1);// []
Array.prototype.slice = function(start,end){ var result = new Array(); start = start || 0; end = end || this.length; //this指向調用的對象,當用了call後,可以改變this的指向,也就是指向傳進來的對象,這是關鍵 for(var i = start; i < end; i++){ result.push(this[i]); } return result; }
var toArray = function(s){ try{ return Array.prototype.slice.call(s); } catch(e){ var arr = []; for(var i = 0,len = s.length; i < len; i++){ //arr.push(s[i]); arr[i] = s[i]; //console.timeEnd測試之後比push快 } return arr; } }