当前位置:首页 > 开发 > 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

    震惊

    震惊

编辑推荐
举例说明: 拿第一个数分别与其他的数去比较,取出最大或最小,将结果放在第一个数中,然后在拿第二
u 数组的排序 这里我们介绍一些常用的排序方法, 排序是一个程序员基本功, 所谓排序就是对一组数据,
题目: 有一个无序、元素个数为2n的正整数数组,要求:如何能吧这个数组分割为元素个数为n的两个数
题目: 有一个无序、元素个数为2n的正整数数组,要求:如何能吧这个数组分割为元素个数为n的两个数
据大家所知的,快速排序是目前的一种非常快的排序方法,它是由C. A. R. Hoare在1962年提出。它的基
public class Work { public static void main(String[] args){ System.out.println("排序后的数组
对保存在数组中的相关数据进行排序是一件非常有意义的事情。在PHP中提供了很多函数可以对数组进行排
前面转载过一片关于js数组的一些基本能操作方法,本文结合实例对数组排序做简要探讨。 首先看一实例
引: StringTokenizer 存在于 java.util. StringTokenizer 包中,是一个用来分隔String的应用类,相
最近一直看编程之美,想法真的很重要,今天发这篇文章还是有一点不自信,希望碰到志同道合的同学一
版权所有 IT知识库 CopyRight © 2009-2015 IT知识库 IT610.com , All Rights Reserved. 京ICP备09083238号