JavaScript數(shù)組的排序

簡(jiǎn)介
不論在哪一種編程的語(yǔ)言中琅翻,排序都是必備的,所以JS也有自己的排序規(guī)則

語(yǔ)法

arr.sort([compareFunction])

參數(shù)
compareFunction 可選

用來(lái)指定按某種順序進(jìn)行排列的函數(shù)蛇券。如果省略缔恳,元素按照轉(zhuǎn)換為的字符串的各個(gè)字符的Unicode位點(diǎn)進(jìn)行排序。

返回值
排序后的數(shù)組病袄。請(qǐng)注意搂赋,數(shù)組已原地排序,并且不進(jìn)行復(fù)制益缠。

描述

如果沒(méi)有指明 compareFunction 脑奠,那么元素會(huì)按照轉(zhuǎn)換為的字符串的諸個(gè)字符的Unicode位點(diǎn)進(jìn)行排序。例如 "Banana" 會(huì)被排列到 "cherry" 之前幅慌。當(dāng)數(shù)字按由小到大排序時(shí)宋欺,9 出現(xiàn)在 80 之前,但因?yàn)椋](méi)有指明 compareFunction)胰伍,比較的數(shù)字會(huì)先被轉(zhuǎn)換為字符串齿诞,所以在Unicode順序上 "80" 要比 "9" 要靠前。

如果指明了 compareFunction 骂租,那么數(shù)組會(huì)按照調(diào)用該函數(shù)的返回值排序祷杈。即 a 和 b 是兩個(gè)將要被比較的元素:

  • 如果 compareFunction(a, b) 小于 0 ,那么 a 會(huì)被排列到 b 之前渗饮;
  • 如果 compareFunction(a, b) 等于 0 但汞, a 和 b 的相對(duì)位置不變宿刮。備注: ECMAScript 標(biāo)準(zhǔn)并不保證這一行為,而且也不是所有瀏覽器都會(huì)遵守(例如 Mozilla 在 2003 年之前的版本)特占;
  • 如果 compareFunction(a, b) 大于 0 糙置, b 會(huì)被排列到 a 之前。
  • compareFunction(a, b) 必須總是對(duì)相同的輸入返回相同的比較結(jié)果是目,否則排序的結(jié)果將是不確定的谤饭。

所以,比較函數(shù)格式如下:

function compare(a, b) {
  if (a < b ) {           // 按某種排序標(biāo)準(zhǔn)進(jìn)行比較, a 小于 b
    return -1;
  }
  if (a > b ) {
    return 1;
  }
  // a must be equal to b
  return 0;
}

要比較數(shù)字而非字符串懊纳,比較函數(shù)可以簡(jiǎn)單的以 a 減 b揉抵,如下的函數(shù)將會(huì)將數(shù)組升序排列

function compareNumbers(a, b) {
  return a - b;
}

sort 方法可以使用 函數(shù)表達(dá)式 方便地書(shū)寫(xiě):

ar numbers = [4, 2, 5, 1, 3];
numbers.sort(function(a, b) {
  return a - b;
});
console.log(numbers);

也可以寫(xiě)成:
var numbers = [4, 2, 5, 1, 3]; 
numbers.sort((a, b) => a - b); 
console.log(numbers);

// [1, 2, 3, 4, 5]

對(duì)象可以按照某個(gè)屬性排序:

var items = [
  { name: 'Edward', value: 21 },
  { name: 'Sharpe', value: 37 },
  { name: 'And', value: 45 },
  { name: 'The', value: -12 },
  { name: 'Magnetic' },
  { name: 'Zeros', value: 37 }
];

// sort by value
items.sort(function (a, b) {
  return (a.value - b.value)
});

// sort by name
items.sort(function(a, b) {
  var nameA = a.name.toUpperCase(); // ignore upper and lowercase
  var nameB = b.name.toUpperCase(); // ignore upper and lowercase
  if (nameA < nameB) {
    return -1;
  }
  if (nameA > nameB) {
    return 1;
  }

  
// names must be equal

  return 0;
});
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市嗤疯,隨后出現(xiàn)的幾起案子冤今,更是在濱河造成了極大的恐慌,老刑警劉巖茂缚,帶你破解...
    沈念sama閱讀 219,270評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件戏罢,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡脚囊,警方通過(guò)查閱死者的電腦和手機(jī)龟糕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)悔耘,“玉大人讲岁,你說(shuō)我怎么就攤上這事〕囊裕” “怎么了缓艳?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,630評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀(guān)的道長(zhǎng)看峻。 經(jīng)常有香客問(wèn)我阶淘,道長(zhǎng),這世上最難降的妖魔是什么互妓? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,906評(píng)論 1 295
  • 正文 為了忘掉前任舶治,我火速辦了婚禮,結(jié)果婚禮上车猬,老公的妹妹穿的比我還像新娘霉猛。我一直安慰自己,他們只是感情好珠闰,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布惜浅。 她就那樣靜靜地躺著,像睡著了一般伏嗜。 火紅的嫁衣襯著肌膚如雪坛悉。 梳的紋絲不亂的頭發(fā)上伐厌,一...
    開(kāi)封第一講書(shū)人閱讀 51,718評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音裸影,去河邊找鬼挣轨。 笑死,一個(gè)胖子當(dāng)著我的面吹牛轩猩,可吹牛的內(nèi)容都是我干的卷扮。 我是一名探鬼主播,決...
    沈念sama閱讀 40,442評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼均践,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼晤锹!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起彤委,我...
    開(kāi)封第一講書(shū)人閱讀 39,345評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤鞭铆,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后焦影,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體车遂,經(jīng)...
    沈念sama閱讀 45,802評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評(píng)論 3 337
  • 正文 我和宋清朗相戀三年斯辰,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了舶担。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,117評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡椒涯,死狀恐怖柄沮,靈堂內(nèi)的尸體忽然破棺而出回梧,到底是詐尸還是另有隱情废岂,我是刑警寧澤,帶...
    沈念sama閱讀 35,810評(píng)論 5 346
  • 正文 年R本政府宣布狱意,位于F島的核電站湖苞,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏详囤。R本人自食惡果不足惜财骨,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望藏姐。 院中可真熱鬧隆箩,春花似錦、人聲如沸羔杨。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,011評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)兜材。三九已至理澎,卻和暖如春逞力,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背糠爬。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,139評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工寇荧, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人执隧。 一個(gè)月前我還...
    沈念sama閱讀 48,377評(píng)論 3 373
  • 正文 我出身青樓揩抡,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親殴玛。 傳聞我的和親對(duì)象是個(gè)殘疾皇子捅膘,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • 第5章 引用類(lèi)型(返回首頁(yè)) 本章內(nèi)容 使用對(duì)象 創(chuàng)建并操作數(shù)組 理解基本的JavaScript類(lèi)型 使用基本類(lèi)型...
    大學(xué)一百閱讀 3,237評(píng)論 0 4
  • ??引用類(lèi)型的值(對(duì)象)是引用類(lèi)型的一個(gè)實(shí)例寻仗。 ??在 ECMAscript 中,引用類(lèi)型是一種數(shù)據(jù)結(jié)構(gòu)凡壤,用于將數(shù)...
    霜天曉閱讀 1,059評(píng)論 0 1
  • JavaScript語(yǔ)言精粹 前言 約定:=> 表示參考相關(guān)文章或書(shū)籍; JS是JavaScript的縮寫(xiě)署尤。 本書(shū)...
    微笑的AK47閱讀 581評(píng)論 0 3
  • 今天看了余華的兄弟,看到了110頁(yè)亚侠,最近在微信讀書(shū)上看的書(shū)太多了曹体,蔣勛說(shuō)紅樓夢(mèng)看到了八百多頁(yè),還是應(yīng)該買(mǎi)紙質(zhì)書(shū)的硝烂,...
    曉寒云輕閱讀 116評(píng)論 0 0
  • 【你愛(ài)我了嗎】 當(dāng)我開(kāi)口對(duì)你說(shuō) 一個(gè)人的夜會(huì)不會(huì)哭 會(huì)不會(huì)在夢(mèng)與醒間游走 任憑回憶刺穿時(shí)間的毒 你會(huì)偶爾和我聊 那...
    王力黑閱讀 125評(píng)論 0 1