js中数组的排序

[javascript] view plain copy 在CODE上查看代码片 派生到我的代码片
  1. console.log("------默认排序(ASCII字符排序)------");  
  2. var arr = [1,2,55,12,88];  
  3. arr.sort();  //ASCII字符代码从小到大排序  
  4. console.log(arr.toString());  
  5.   
  6. console.log("------自定义函数排序------");  
  7. var arr1 = [1,2,55,12,88];  
  8. arr1.sort(function(a,b){  //自定义函数排序  
  9.     var a1= parseInt(a);  
  10.     var b1= parseInt(b);  
  11.     if(a1<b1){  
  12.         return -1;  
  13.     }else if(a1>b1){  
  14.         return 1;  
  15.     }  
  16.     return 0;  
  17. });  
  18. console.log(arr1.toString());  
  19.   
  20. console.log("------反转数组------");  
  21. var reArr = arr1.reverse();  //将数组中元素的顺序倒转  
  22. console.log(reArr.toString());  
  23.   
  24. console.log("------按年龄正序排序------");  
  25. var arr2 = [];  
  26. arr2.push({date:"20130101",name:"lee",age:2});  
  27. arr2.push({date:"20130101",name:"wang",age:12});  
  28. arr2.push({date:"20130202",name:"huang",age:30});  
  29. arr2.push({date:"20130202",name:"keke1",age:14});  
  30. arr2.push({date:"20130202",name:"keke2",age:31});  
  31. arr2.push({date:"20130303",name:"keke3",age:56});  
  32. arr2.push({date:"20130303",name:"keke4",age:22});  
  33. arr2.push({date:"20130303",name:"keke5",age:32});  
  34. arr2.sort(function(a,b){  
  35.     if(a.age<b.age){  
  36.         return -1;  
  37.     }else if(a.age>b.age){  
  38.         return 1;  
  39.     }  
  40.     return 0;  
  41. });  
  42. for(var i=0;i<arr2.length;i++){  
  43.     console.log(arr2[i].date + ", " + arr2[i].name + ", " + arr2[i].age);  
  44. }  
  45.   
  46. console.log("------按date倒序,age正序排序------");  
  47. arr2.sort(function(a,b){  
  48.     if(a.date<b.date){  
  49.         return 1;  
  50.     }else if(a.date>b.date){  
  51.         return -1;  
  52.     }else{  
  53.         if(a.age<b.age){  
  54.             return -1;  
  55.         }else if(a.age>b.age){  
  56.             return 1;  
  57.         }  
  58.         return 0;  
  59.     }  
  60. });  
  61. for(var i=0;i<arr2.length;i++){  
  62.     console.log(arr2[i].date + ", " + arr2[i].name + ", " + arr2[i].age);  
  63. }  

运行结果:

------默认排序(ASCII字符排序)------ 
1,12,2,55,88 
------自定义函数排序------
1,2,12,55,88 
------反转数组------ 
88,55,12,2,1 
------按年龄正序排序------ 
20130101, lee, 2 
20130101, wang, 12 
20130202, keke1, 14 
20130303, keke4, 22 
20130202, huang, 30 
20130202, keke2, 31 
20130303, keke5, 32 
20130303, keke3, 56 
------按日期倒序,年龄正序排序------ 
20130303, keke4, 22 
20130303, keke5, 32 
20130303, keke3, 56 
20130202, keke1, 14 
20130202, huang, 30 
20130202, keke2, 31 
20130101, lee, 2 
20130101, wang, 12 

 

多维数组定义

定义数组数组对象用来在单独的变量名中存储一系列的值。使用关键词 new 来创建数组对象。

一维数组定义

var myArray=new Array('a','b','c'); 或 var myArray = [];

二维数组及多维数组定义

javascript二维数组或多维数组都是通过一维数组来模拟起来.

方法1.

var  arr= new Array(['a','b','c'],['d','e','f']);

方法2:

var  arr=new   Array(

  new   Array(),   

  new   Array(),  

  new   Array()   

);

数组访问:

arr[行][列];

如:  

arr[0][0]  // a

arr[1][0]  //d      

hash数组定义

JavaScript中的关联数组,关联数组因为有key值的索引,所以在数组查找中比较便利,同时也使得相应的代码算法实现显得更清晰,易读易维护.

var myhash = new Array();

向Hash关联数组添加键值

myhash['new'] = 'newval';

myhash['new2'] = 'newval_2';

访问Hash关联数组

myhash['new'];  // 跟上键名就能访问

删除Hash数组已有键值delete myhash['new'];

遍历Hash数组

for(key in myhash){    console.log(key);  //key 获取的是键名    myhash[key];  // 获取值}

js数组操作常用方法

toString():把数组转换成一个字符串

toLocaleString():把数组转换成一个字符串

join():把数组转换成一个用符号连接的字符串

shift():将数组头部的一个元素移出

unshift():在数组的头部插入一个元素

pop():从数组尾部删除一个元素

push():把一个元素添加到数组的尾部

concat():给数组添加元素

slice():返回数组的部分

reverse():将数组反向排序

sort():对数组进行排序操作

splice():插入、删除或者替换一个数组元素


根据日期最小的那天的开始和结束时间

function split2Object(){
		var stringArr=[
		               "14081160917739755143997185288300092016-03-0413:00",
			"14081160917739755143997185288300092016-03-0414:00",
			"14081160917739755143997185288300092016-03-0613:00",
			"14081160917739755142371188668900962016-03-0613:00",
			"14081160917739755142371188668900962016-03-0413:00",
			"14081160917739755142371188668900962016-03-0614:00"];
		var objArr=[];
		for (var i = 0; i < stringArr.length; i++) {
			var temp=stringArr[i];
			var gymId=temp.substr(0,"14081160917739755".length);
			var yardId=temp.substr("14081160917739755".length,"14237118866890096".length);
			var date=temp.substr("1408116091773975514237118866890096".length,"2016-03-04".length).replace(/-/g,"");
			var time=temp.substr("14081160917739755142371188668900962016-03-04".length,"13:00".length).replace(":","");
			objArr.push({"gymId":gymId,"yardId":yardId,"date":date,"time":time,"datetime":date+time,"id":temp});
		}
		var sortArr=sort(objArr);
		var endData=getEndData(sortArr);
		console.log(sortArr[0])//开始
		console.log(endData);//结束
	}
	function sort(arr){
		arr.sort(function(a,b){  
		    if(a.datetime<b.datetime){  
		        return -1;  
		    }else if(a.datetime>b.datetime){  
		        return 1;  
		    }  
		    return 0;  
		});  
//		for(var i=0;i<arr2.length;i++){  
//		    console.log(arr2[i].id + ", " + arr2[i].date + ", " + arr2[i].time+", " + arr2[i].datetime+", " + arr2[i].yardId);  
//		}  
		  
		/*console.log("------按datetime正序,age正序排序------");  
		arr2.sort(function(a,b){  
		    if(a.datetime<b.datetime){  
		        return -1;  
		    }else if(a.datetime>b.datetime){  
		        return 1;  
		    }else{  
		        if(a.yardId<b.yardId){  
		            return -1;  
		        }else if(a.yardId>b.yardId){  
		            return 1;  
		        }  
		        return 0;  
		    }  
		});  
		for(var i=0;i<arr2.length;i++){  
			console.log(arr2[i].id + ", " + arr2[i].date + ", " + arr2[i].time+", " + arr2[i].datetime+", " + arr2[i].yardId);  
		}*/
		return arr;
	}
	function getEndData(arr){
		var firstData=arr[0];
		var endData=firstData;
		for(var i=1;i<arr.length;i++){
			console.log(arr[i].yardId+";"+firstData.yardId+";"+arr[i].date+";"+firstData.date);
			if(arr[i].yardId==firstData.yardId&&arr[i].date==firstData.date){
				endData=arr[i];
				console.log(endData);
			}
      }
		return endData;
	}


  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值