2016-08-16 43 views
0

我有一个字符串数组,即章节序列。我应该按照顺序排列数组。如何在JavaScript中安排顺序?

样品

var item = ["1.1", "1.1.1", "17.10", "13.11", "11.12", "17.7.a", "6.11", "6.11.1", "1.2", "1.2.1", "1.2.2.a"] 
 

 
console.log("After Sort : " + item.sort());

但预期的结果是

["1.1", "1.1.1", "1.2", "1.2.1", "1.2.2.a", "6.11", "6.11.1", "11.12", "13.11", "17.7.a", "17.10"] 

更新

我得到了答案,从这个reference

Array.prototype.humanSort = function() { 
    return this.sort(function(a, b) { 
    aa = a.split(/(\d+)/); 
    bb = b.split(/(\d+)/); 

    for(var x = 0; x < Math.max(aa.length, bb.length); x++) { 
     if(aa[x] != bb[x]) { 
     var cmp1 = (isNaN(parseInt(aa[x],10)))? aa[x] : parseInt(aa[x],10); 
     var cmp2 = (isNaN(parseInt(bb[x],10)))? bb[x] : parseInt(bb[x],10); 
     if(cmp1 == undefined || cmp2 == undefined) 
      return aa.length - bb.length; 
     else 
      return (cmp1 < cmp2) ? -1 : 1; 
     } 
    } 
    return 0; 
    }); 
} 
+0

'“1.1.1”'不能是数字...... – Rayon

+0

@Rayon OP很明显地说“字符串数组”,我不知道你为什么要考虑数字。 –

+0

@NiettheDarkAbsol - 在这种情况下,我期待着一个'compareFunction'。 – Rayon

回答

0

每个项目可以很容易地.split(".")获得部件的阵列。这是你可以分类的东西。

像这样的事情会做到这一点:

item.sort(function(a,b) { 
    a = a.split("."); 
    b = b.split("."); 
    while(a.length && b.length) { 
     if(a[0] == b[0]) { 
      a.shift(); 
      b.shift(); 
      continue; 
     } 
     if(a[0] < b[0]) return -1; 
     return 1; 
    } 
    if(b.length) return -1; // same items but b has more after that 
    if(a.length) return 1; 
    return 0; 
}); 

这会给你想要的排序顺序。

相关问题