作個記錄,主要是對數位處理,如果數位前面字元是相同的,則數字以值比較,而不是單個字元之間的比較。
function SortLikeWin(v1, v2) {var a = v1.name;var b = v2.name;var reg = /[0-9]+/g;var lista = a.match(reg);var listb = b.match(reg);if (!lista || !listb) {return a.localeCompare(b);}for (var i = 0, minLen = Math.min(lista.length, listb.length) ; i < minLen; i++) {//數字所在位置序號var indexa = a.indexOf(lista[i]);var indexb = b.indexOf(listb[i]);//數字前面的首碼var prefixa = a.substring(0, indexa);var prefixb = a.substring(0, indexb);//數位stringvar stra = lista[i];var strb = listb[i];//數位值var numa = parseInt(stra);var numb = parseInt(strb);//如果數位序號不等或首碼不等,屬於首碼不同的情況,直接比較if (indexa != indexb || prefixa != prefixb) {return a.localeCompare(b);}else {//數位string全等if (stra === strb) {//如果是最後一個數字,比較數位尾碼if (i == minLen - 1) {return a.substring(indexa).localeCompare(b.substring(indexb));}//如果不是最後一個數字,則迴圈跳轉到下一個數字,並去掉前面相同的部分else {a = a.substring(indexa + stra.length);b = b.substring(indexa + stra.length);}}//如果數位string不全等,但值相等else if (numa == numb) {//直接比較數字首碼0的個數,多的更小return strb.lastIndexOf(numb + '') - stra.lastIndexOf(numa + '');}else {//如果數字不等,直接比較數字大小return numa - numb;}}}}
使用方法,Array.sort(SortLikeWin);
以上所述是小編給大家介紹的基於JS模仿windows檔案按名稱排序效果,希望對大家有所協助,如果大家有任何疑問請給我留言,小編會及時回複大家的。在此也非常感謝大家對雲棲社區網站的支援!