今天,使用Node.js开发一个报表时,遇到了一个问题,对数组进行排序,由于这个数据中的每个元素都是JSON,结果就去百度了以下。结果发现了可以使用sort()方法。
如下所示,对数组中的元素进行了升序。
<html>
<body οnlοad="init()">
</body>
<script>
function init(){
var array = new Array();
array.push('3');
array.push('2');
array.push('5');
array.push('1');
array.sort();
alert(array.toString());
}
</script>
</html>
那么,当数组中的元素为JSON字符串时,如何进行排序呢,这就要使用sort()的另一个方式了。在node.js中可以使用Date.parse对字符串类型的日期进行转换:
exports.getReportList = function(req,res){
var type = req.body.type;
var startDate = req.body.startDate;
var endDate = req.body.endDate;
ftpTxt.findOne(function(err,ftpTxt){
if(err){
log.writeErr(err);
} else{
var array = new Array();
for(var key in ftpTxt[type]) {
for(var val in ftpTxt[type][key]){
if(val >= startDate && val<=endDate){
array.push(ftpTxt[type][key][val]);
}
}
}
array.sort(function(a,b){
return -(Date.parse(a["Date"]) - Date.parse(b["Date"]));
});
res.json({data:array});
}
});
}
这样,就可以使用此方法进行排序,上例中使用的是降序排序。