我有一个包含字符串的数组,如下所示:

["2013-1", "2013-10", "2013-11", "2013-12", "2013-2", "2013-3", "2013-4", "2014-1", "2014-2", "2014-3"]


我正在尝试对它们进行排序,使它们看起来像:

["2013-1", "2013-2", "2013-3", "2013-4", "2013-10", "2013-11", "2013-12", "2014-1", "2014-2", "2014-3"]


我已经检查了很多关于该主题的主题,但是没有一个解决方案对我有用。

使用this问题的答案,我的数组完全没有改变。

var myArray =  ["2013-1", "2013-10", "2013-11", "2013-12", "2013-2", "2013-3", "2013-4", "2014-1", "2014-2", "2014-3"]
    myArray.sort(function(a,b) {
      if (isNaN(a) || isNaN(b)) {
        return a > b ? 1 : -1;
      }
      return a - b;
    });


似乎找不到一种轻松做到这一点的方法,如何实现它的任何想法?

最佳答案

问题在于,不仅仅是字符串数组中的数字,每个字符串中还有两个数字。有很多可能的方法,您可以将值解析为日期,可以将值解析为两个数字,可以将值拆分为字符串和数字,等等。

我建议的方法是将每个字符串转换为可比较的格式,即将类似"2013-1"的字符串转换为2013-01。由于字符串中的每个组成部分都具有相同的长度,并且这些组成部分的重要性不断下降,因此您可以将它们作为字符串进行比较:

myArray.sort(function(a,b) {
  var x = a.replace(/(-\d$)/, '-0$1');
  var y = b.replace(/(-\d$)/, '-0$1');
  return (
    x > y ? 1 :
    x < y ? -1 :
    0
  );
});




var myArray = ["2013-1", "2013-10", "2013-11", "2013-12", "2013-2", "2013-3", "2013-4", "2014-1", "2014-2", "2014-3"];

myArray.sort(function(a,b) {
  var x = a.replace(/(-\d$)/, '-0$1');
  var y = b.replace(/(-\d$)/, '-0$1');
  return (
    x > y ? 1 :
    x < y ? -1 :
    0
  );
});

// output result in StackOverflow snippet
document.write(JSON.stringify(myArray));

10-08 11:43
查看更多