JS 陣列排序範例

馬老師離開待了約十幾年的教學界,目前在外商科技公司擔任Senior Consultant的工作,原因當然很多,未來有空再慢慢發文章分享,剛好最近有點時間,怕以後忘記,把最近專案中用到的一些程式筆記下來,如果大家有需要,也可以參考使用,這一篇是關於Javascript陣列排序的部分。

通常若有較多的內容需要儲存,變數就沒有陣列來的好用,所以陣列是拿來儲存大量的資料時所使用的,且儲存在裡面的資料,還可以選擇經過排序之後再呈現至畫面上,例如:

var name = ["stanley", "jack", "anita" , "mary"];

name.sort() //依照字母排序
console.log(name); // 輸出 ["anita", "jack", "mary", "stanley"]

names.reverse() //反轉陣列內容
console.log(name); //輸出 ["stanley", "mary", "jack", "anita"]

但若我們同時有多個陣列,但希望以其中之一的內容排序時,也可以同步更新到另外一個陣列,該如何處理呢?可以參考以下的方式:

var name = ["stanley", "jack", "anita" , "mary"];
var gender = ["male" , "male" , "female" , "female"];
var score = [30, 10, 40 , 80];
var ID = ["S1" , "S2" , "S3" , "S4"];

console.log("name : " + name + "; score : " + score + "; gender : " + gender + "; ID : " + ID);
/*
排序前
name : stanley,jack,anita,mary;
score : 30,10,40,80;
gender : male,male,female,female;
ID : S1,S2,S3,S4;
*/

var list = [];
for (var i = 0; i < name.length; i++){
  list.push({
    'name': name[i],
    'score': score[i],
    'gender': gender[i],
    'ID': ID[i]
  });
}

list.sort(function(a, b) {
  return ((a.name < b.name) ? -1 : ((a.name == b.name) ? 0 : 1));
});

for (var i = 0; i < list.length; i++) {
  name[i] = list[i].name;
  score[i] = list[i].score;
  gender[i] = list[i].gender;
  ID[i] = list[i].ID;
}

console.log("name : " + name + "; score : " + score + "; gender : " + gender + "; ID : " + ID);
/*
排序後
name : anita,jack,mary,stanley;
score : 40,10,80,30;
gender : female,male,female,male;
ID : S3,S2,S4,S1;
*/

若是希望按照分數排序,則可以將sort function 修改為下:

//score 由小到大
list.sort(function(a, b) {
  return a.score - b.score
});

//score 由大到小
list.sort(function(a, b) {
  return b.score - a.score
});

補充:

上述的排序內容均以英文和數字為主,若是遇到中文可使用localeCompare進行,而排序的方式是漢語拼音順序,以下為範例:

var arr = ["二","五","四","一","三"];
//漢語拼音:一[yi], 二[er], 三[san], 四[si], 五[wu]
console.log("排序前:" + arr); // 排序前:二,五,四,一,三
arr.sort(function(a,b){
	return a.localeCompare(b, 'zh'); //排序後:二,三,四,五,一
});
console.log("排序後:" + arr); 

var arr = ["中文","英語","法國話", "京片子", "中國"];
//中文[zhong wen], 英語[ying yu], 法國話[fa guo hua], 京片子[jing pian zi], 中國[zhong guo]
console.log("排序前:" + arr); //排序前:中文,英語,法國話,京片子,中國
arr.sort(function(a,b){
	return a.localeCompare(b, 'zh');
});
console.log("排序後:" + arr); //排序後:法國話,京片子,英語,中國,中文


var arr = ["中文","英语","法国话", "京片子", "中国"];
console.log("排序前:" + arr); //排序前:中文,英语,法国话,京片子,中国
arr.sort(function(a,b){
	return a.localeCompare(b, 'zh');
});
console.log("排序後:" + arr); //排序後:法国话,京片子,英语,中国,中文

You may also like...

13,714 Responses

  1. Diplomi_agEa表示:

    купить диплом бакалавра в екатеринбурге 1oriks-diplom199.ru .

  2. xxx_bbma表示:

    . [url=http://diklikaja.com/smartblog/85_review-adata-xpg-ex500-enclosure-hdd-ssd-sata.html/]http://diklikaja.com/smartblog/85_review-adata-xpg-ex500-enclosure-hdd-ssd-sata.html/[/url] .

  3. xxx_rsMi表示:

    . [url=http://doodleordie.com/profile/hetoh22353/]http://doodleordie.com/profile/hetoh22353/[/url] .

  4. xxx_eyKa表示:

    . [url=https://sexvideos.usite.pro/blog/exploring_the_world_of_high_definition_xxx_videos/2024-10-28-3]https://sexvideos.usite.pro/blog/exploring_the_world_of_high_definition_xxx_videos/2024-10-28-3[/url] .

  5. вывод из запоя ростов-на-дону [url=https://rio16.ukrbb.net/viewtopic.php?f=3&t=1112/]https://rio16.ukrbb.net/viewtopic.php?f=3&t=1112/[/url] .

  6. Danieljek表示:

    amoxicillin price canada https://clomidrexpharm.com/# can i buy cheap clomid without dr prescription

  7. Bradleygoath表示:

    can you get generic clomid online buy clomid can you get generic clomid tablets

  8. вывод из запоя цены ростов на дону uaforum.ukrbb.net/viewtopic.php?f=13&t=3230 .

  9. Предлагаем услуги профессиональных инженеров офицальной мастерской.
    Еслли вы искали сервисный центр xiaomi в москве, можете посмотреть на сайте: официальный сервисный центр xiaomi
    Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!

  10. Узнай все о варикоцеле причины заболевание варикоцеле

  11. This is the perfect web site for anybody who really wants to understand this topic. You realize a whole lot its almost hard to argue with you (not that I actually would want to…HaHa). You definitely put a brand new spin on a subject which has been written about for many years. Wonderful stuff, just great.

  12. Узнай все о чем опасно варикоцеле рецидив варикоцеле

  13. porn表示:

    I’m amazed, I have to admit. Rarely do I come across a blog that’s both equally educative and interesting, and without a doubt, you have hit the nail on the head. The issue is an issue that too few men and women are speaking intelligently about. I’m very happy I came across this during my search for something regarding this.

  14. Предлагаем услуги профессиональных инженеров офицальной мастерской.
    Еслли вы искали сервисный центр xiaomi в москве, можете посмотреть на сайте: сервисный центр xiaomi
    Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!

  15. Pyajcc表示:

    гѓ—гѓ¬гѓ‰гѓ‹гѓігЃ®иіје…Ґ – гѓ—гѓ¬гѓ‰гѓ‹гѓі гЃЇйЂљиІ©гЃ§гЃ®иіј アジスロマイシン錠 500mg еј·гЃ•

  16. вывод из запоя цена ростов uaforum.ukrbb.net/viewtopic.php?f=13&t=3230 .

  17. Excellent post! We are linking to this particularly great content on our site. Keep up the great writing.

  18. xnxx tube表示:

    Spot onn witgh thks write-up, I serikously believe thhat this amazing site needs a
    grdat dral mofe attention. I’ll probably bbe returning too redad more,
    thamks for thhe information!

  19. Узнай все о варикоцеле левого яичка лапароскопия варикоцеле

  20. porn表示:

    I’m impressed, I must say. Rarely do I come across a blog that’s both educative and amusing, and without a doubt, you have hit the nail on the head. The issue is an issue that too few folks are speaking intelligently about. Now i’m very happy that I stumbled across this during my search for something concerning this.

  21. StevenNub表示:

    amoxicillin 500 mg tablet: amoxicillin 500 mg where to buy – amoxicillin 500 coupon

  22. Предлагаем услуги профессиональных инженеров офицальной мастерской.
    Еслли вы искали сервисный центр xiaomi в москве, можете посмотреть на сайте: сервисный центр xiaomi
    Наши мастера оперативно устранят неисправности вашего устройства в сервисе или с выездом на дом!

發佈留言

發佈留言必須填寫的電子郵件地址不會公開。