当前位置:首页 > 开发 > Web前端 > JavaScript > 正文

JavaScript数组的分割和排序

发表于: 2013-02-01   作者:boonya   来源:转载   浏览:
摘要: 1. 数组分割:array.slice(start, end) slice()是用来截取数组中的一部分,用它来复制数组,如果省略了end参数,则切分的数组包含从start开始到数组结束的所有元素。 现在要用它来复制数组:var newArray=oldArray.slice(0); (1). 如果 start 为负,将它作为 length + start处理,此处 length 为数
1. 数组分割:array.slice(start, end)

slice()是用来截取数组中的一部分,用它来复制数组,如果省略了end参数,则切分的数组包含从start开始到数组结束的所有元素。

现在要用它来复制数组:var newArray=oldArray.slice(0);
(1). 如果 start 为负,将它作为 length + start处理,此处 length 为数组的长度,比如a.slice(-3,4),相当于a.slice(2,4)。

(2). 如果 end 为负,就将它作为 length + end 处理,此处 length 为数组的长度,比如a.slice(0,-1)。

(3). 如果省略 end ,那么 slice 方法将一直复制到源数组结尾,比如a.slice(1)。如果 end 出现在 start 之前,不复制任何元素到新数组中,比如a.slice(4,3)。

(4).对于字符串,也有slice(start,end)方法。
示例:


/**
 *将数组分割成新的数组[二维数组]
 *@param myArray 需要分割的数组
 *@param size    分割每个子数组的长度
 */
function getNewArray(myArray,size){
  var len=parseInt(myArray.length/size);
  var remain=myArray.length%size;
  var my_array=[],count=1,sot=remain>0?len+1:len; 
  for ( var f = 1; f <=sot; f++) {
    var start=size*(f-1);
    var end=(f>len)?((f-1)*size+remain):f*size;
    var mylocates=myArray.slice(start,end);
    my_array.push(mylocates);
  }
 return my_array;
}

2.数组排序:array.sort()
(1)、默认的sort()按字符编码排序的:

var testArray=[3,324,5345,6546,134,5654,665];
 testArray.sort();
 alert(testArray.join(","));

(2)、按大小排序:
var testArray=[3,324,5345,6546,134,5654,665];
testArray.sort(function(a,b){return a-b;});
alert(testArray.join(","));

//说明:alert(arr.sort(function(left,right){return left>right?-1:1}))   ////这里,sort方法通过参数函数的返回值 1或者-1来决定是顺排还是倒排
(3)、对多维数组的排序:
var arr=[
              [2,1,55,4],
              [5,3,22,3],
              [1,2,77,2],
              [9,4,33,5],
           ];                 
alert("默认按第一列排\n"+arr.sort().join("\n"));
alert("现在按第三列排\n"+arr.sort(function(left,right){return left[2]>right[2]?1:-1}).join("\n"));
alert("现在按第三列倒排\n"+arr.sort(function(left,right){return left[2]>right[2]?-1:1}).join("\n"));

JavaScript数组的分割和排序

  • 0

    开心

    开心

  • 0

    板砖

    板砖

  • 0

    感动

    感动

  • 0

    有用

    有用

  • 0

    疑问

    疑问

  • 0

    难过

    难过

  • 0

    无聊

    无聊

  • 0

    震惊

    震惊

版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号