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...

19,599 Responses

  1. 10 Unexpected Locksmith Near Me Open Now Tips locksmiths near me Open now

  2. The extraction and refining processes are energy-intensive and infrequently rely on fossil fuels, leading to increased carbon dioxide emissions and exacerbating local weather change.

  3. Nevertheless, the availability of uncooked materials in massive quantities may represent a future weakness, as not all are renewable.

  4. Williecrady表示:

    Mesin slot digital semakin banyak diminati http://slot88.company/# Kasino mendukung permainan bertanggung jawab

  5. DavidCooth表示:

    http://slotdemo.auction/# Slot dengan tema budaya lokal menarik perhatian

  6. Clover, Juli (April 3, 2014).

  7. Why You Should Focus On Improving Private Mental Health Assessment
    291 Mental Health Assessment

  8. ThomasThype表示:

    Beberapa kasino memiliki area khusus untuk slot: garuda888 slot – garuda888.top

  9. Aaronbus表示:

    garuda888 garuda888.top Kasino di Jakarta memiliki berbagai pilihan permainan

  10. Williecrady表示:

    Jackpot progresif menarik banyak pemain http://preman69.tech/# Mesin slot digital semakin banyak diminati

  11. DavidCooth表示:

    http://preman69.tech/# Bermain slot bisa menjadi pengalaman sosial

  12. You will see that very good information concerning instruments utilized by the world’s greatest technical analysts to guage emerging trends.

  13. DannyUnded表示:

    How Nigeria’s biggest city became the world’s hottest winter party destination
    casino bonus

    It’s a world of endless parties and sleepless nights. A relentless celebration that turns West Africa – and especially Nigeria’s largest city, Lagos – into one of the hottest destinations on the continent, if not the planet, right in the middle of winter.

    Detty December is a magical time between December and early January when diaspora communities and tourists flock to Ghana, Nigeria and South Africa for an unforgettable experience filled with flavourful food, soulful African music and sunshine.

    Beach parties, festivals and top-tier performances fuel the energy, while fashion takes center stage, with everyone dressing to impress.

    Nearly two-thirds of Nigeria’s population is under 25, according to the United Nations Population Fund, making this one of the world’s youngest countries.

    Internationally renowned Afrobeats performers and foreign artists make surprise appearances. DJs take to the streets, blasting powerful beats from consoles mounted atop bright yellow minibuses.

    At times it’s all-consuming. Good luck getting hair salon appointments, affordable air tickets or navigating Lagos’ already notorious traffic when the party crowds are in town.

    Detty December (“detty” is a playful corruption of “dirty”) is a triumphant celebration of culture, music and good vibes that has evolved in recent years during the traditional holidays influx of diaspora returnees, which heightened in 2018 when Ghana ran a launched a successful “Year of Return” campaign actively encouraging people to visit their ancestral homelands.

    It’s gathered pace over the past five years, gaining an international reputation, as IJGBs (“I Just Got Backs”) and their friends arrive in batches, eager to unwind and blow off steam after the fast-paced, hard-working year they’ve had overseas.

    For many in the vast Nigerian diaspora, it is a deeply personal homecoming, a chance to reconnect with their heritage, traditions and families while immersing themselves in the lively energy of Nigerian life.

  14. Buy Verified Stripe Account
    $950.00 Original price was: $950.00.$800.00Current price is: $800.00.

    Buy Stripe Accounts
    Buy Verified Stripe Account efficient payment processing is crucial for businesses of all sizes. Stripe has emerged as a leading solution, offering seamless transactions and a suite of features tailored to modern commerce. This comprehensive guide delves into the advantages of acquiring a Stripe account, Ensuring Secure Transactions with globalusasmm In the world of online payments, Stripe has become a go-to platform globalusasmm.com for businesses.

    Features Of Our Verified Stripe Account:
    Email verified
    Phone number verified
    Debit card attached and verified
    Bank accounts verified and attached
    Bitcoin enable accounts available
    Providing documents confirmed with acc. details
    USA accounts available
    Cheap price for each acc.
    We provide all kinds of accounts of all countries such as USA, UK, Germany, and so on, at cheap rate. If you want to buy accounts (any) visit our website, choose products, place your order and contact fast.

    24 Hours Reply/Contact
    Email:- globalusasmm1@gmail.com
    Whatsapp:- + 1(669)669-7592
    Skype:– globalusasmm
    Telegram:– @globalusasmm

  15. The 10 Most Terrifying Things About Window Seal Repair Near Me
    Window seal repair near me

  16. ThomasThype表示:

    Kasino menawarkan pengalaman bermain yang seru: akun demo slot – slot demo

  17. Williecrady表示:

    Pemain sering mencoba berbagai jenis slot http://slot88.company/# Slot dengan tema budaya lokal menarik perhatian

  18. DavidCooth表示:

    http://slot88.company/# Pemain sering mencoba berbagai jenis slot

  19. What’s The Current Job Market For Tilt And Turn Window Adjustment Professionals?

    Tilt and turn Window adjustment

  20. Rhjxsx表示:

    monodox sale – brand ventolin 4mg glucotrol 10mg brand

  21. ThomasThype表示:

    Slot menjadi bagian penting dari industri kasino: slot demo rupiah – demo slot pg

  22. The equity risk premium can also be used as a portfolio indicator by investors.

  23. Williecrady表示:

    Pemain harus memahami aturan masing-masing mesin http://garuda888.top/# Banyak kasino menawarkan permainan langsung yang seru

  24. Aaronbus表示:

    preman69 slot preman69 slot Slot dengan bonus putaran gratis sangat populer

  25. asikqq表示:

    Pretty nice post. I just stumbled upon your weblog and wanted to say that I have really enjoyed browsing your blog posts. After all I’ll be subscribing to your feed and I hope you write again soon!

  26. janetrramirez表示:

    Buy Verified TransferWise Accounts
    $270.00 – $450.00

    Buying a verified TransferWise account from us means you can bypass the lengthy registration process and start enjoying money-saving benefits immediately. We offer comprehensive support throughout your transaction journey, so you can count on us to assist you whenever needed.

    Our TransferWise Account Service…
    => Guaranteed 100% Satisfaction and Recovery
    => Email Login Access
    => Passport Verified
    => Card + Bank added
    => Provide Full SSN
    => Copy of Driving Licence
    => Provide Date of Birth
    => First delivery
    => Support for 24/7 customers

    24/7 Contact

    Email: usasellservice@gmail.com
    Skype: USASELLSERVICE
    Telegram: @usasellservice

  27. janetrramirez表示:

    Buy Verified Paypal Accounts
    Rated 1.50 out of 5 based on 2customer ratings(2 customer reviews)
    $140.00 – $240.00

    Are you looking to purchase verified PayPal accounts for your business? We offer secure and verified PayPal accounts to individuals as well as businesses. Our professional solutions will help you to enjoy hassle-free payments and increased credibility. Begin your journey towards seamless online payment today!

    Our PayPal Account Service…..
    PayPal email and password.
    Verified phone: Verify any country’s Phone
    Card Verified.
    Bank Verified.
    Passport Verified.
    SSN Verified.
    Email logins for PayPal.
    Use Visa Card or credit card in PayPal.
    Use of Date of birth.
    Driver’s License and Passport.
    Please provide your name, city, Social Security number, and other details.
    Receive and send money with no limits.
    Replacement for 30 days.

    24/7 Contact

    Email: usasellservice@gmail.com
    Skype: USASELLSERVICE
    Telegram: @usasellservice

  28. janetrramirez表示:

    Buy Verified Cashapp Accounts
    $120.00 – $520.00

    We offer verified and secure accounts that are suitable for both personal and business use. You can enjoy hassle-free, secure transactions and enhanced privacy. Cash App is the perfect solution to your financial needs.

    Our Cashapp Account Service…
    => Guaranteed 100% Satisfaction and Recovery
    => Email Login Access
    => Enable 100% BTC withdrawal
    => Card + Bank added
    => Provide Full SSN
    => Provide Date of Birth
    => First delivery
    => Support for 24/7 customers

    24/7 Contact:-
    Email: usasellservice@gmail.com
    Skype: USASELLSERVICE
    Telegram: @usasellservice

發佈留言

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