JavaScriptの配列の並べ替え(sortメソッド)の基本とカスタマイズ
生徒
「先生、JavaScriptで配列の中身を並べ替えたいんですけど、どうやったらいいですか?」
先生
「配列を並べ替えるなら、sortメソッドを使います。これを使うと、文字や数字を簡単に順番に並べることができますよ。」
生徒
「でも、自分の好きな順番に並べることもできますか?」
先生
「もちろんです!基本の使い方から、カスタマイズの方法まで一緒に見ていきましょう!」
1. sortメソッドとは?基本的な使い方
JavaScriptで配列のデータを特定のルールで並べ替えたいときに欠かせないのがsortメソッドです。例えば、名簿を名前順に並べたり、商品の価格を安い順に並べたりするときに非常によく使われます。
プログラミング未経験の方でもイメージしやすいように、まずは「果物の名前」をバラバラに用意して、それを五十音順(正しくはUnicode順)に整列させるサンプルを見てみましょう。
// 並べ替えたい元の配列を作成
let fruits = ["りんご", "バナナ", "みかん"];
// sortメソッドを実行して並べ替える
fruits.sort();
// 結果をコンソールに表示
console.log(fruits);
["バナナ", "みかん", "りんご"]
上記のコードを実行すると、配列の中身が自動的に並べ替えられます。ここで不思議に思うかもしれませんが、JavaScriptの標準的なsortは、文字を「Unicode(ユニコード)」というコンピュータ上の背番号のようなルールに従って比較します。
そのため、今回の例では「バ(は)→み→り」という順番で出力されました。このように、sort()と書くだけで、配列の中身を特定の規則に沿って整列させることができるのです。
基本的には「文字を基準に並べ替える機能」だと覚えておくと、この後の学習がスムーズになりますよ。
2. 数字の配列をsortで並べ替えるときの落とし穴と注意点
JavaScriptのsortメソッドを使って数字を並べ替えようとすると、多くの初心者が「あれ?順番がおかしいぞ」という壁にぶつかります。実は、何も設定せずにsort()を使うと、数字であっても「文字列(テキスト)」として扱われてしまうというルールがあるからです。
例えば、私たちが直感的に数字を並べ替えると「1, 5, 10, 100」となりますが、プログラムの世界では「1で始まるグループ」「5で始まるグループ」といった辞書のような順序で判定されます。その結果、どうなるか実際に確認してみましょう。
// バラバラの数字が入った配列
let numbers = [10, 5, 100, 1];
// そのままsortメソッドを実行
numbers.sort();
// 結果を確認
console.log(numbers);
[1, 10, 100, 5]
実行結果を見ると、1の次に10や100が来て、最後に5が来ていますね。これは「1」という文字で始まるデータが優先され、その後に「5」という文字が並んでいる状態です。まるで辞書で「a」の単語が全部終わってから「b」が始まるのと同じ仕組みです。
このように、数値の大小で正しく並べたい場合には、JavaScriptに「これは文字じゃなくて数字の大きさで比べてね」と教えてあげる必要があります。そのために使用するのが、次で解説する「比較関数」というテクニックです。
3. 比較関数で数字の並べ替えをカスタマイズする
sortメソッドは、並べ替えのルールを自分で決めるために「比較関数」という関数を使えます。この関数は2つの値を比べて、どちらが先か教えます。
数字を小さい順に並べたい場合は、次のように書きます。
let numbers = [10, 5, 100, 1];
numbers.sort(function(a, b) {
return a - b;
});
console.log(numbers);
[1, 5, 10, 100]
この比較関数は、「a - b」の計算結果が0より小さいときはが前、0より大きいときはbが前、0のときは順番を変えないという意味です。
4. 比較関数で数字を大きい順に並べる方法
同じようにして、大きい順に並べたいときはとbを入れ替えて計算します。
let numbers = [10, 5, 100, 1];
numbers.sort(function(a, b) {
return b - a;
});
console.log(numbers);
[100, 10, 5, 1]
これで数字を大きい順に並べることができました。
5. 文字列の並べ替えも比較関数でカスタマイズできる
文字列も比較関数で好きな順番に並べ替えられます。日本語やアルファベットの順番を正しく比較するために localeCompare という便利な関数を使います。
let fruits = ["バナナ", "りんご", "みかん"];
fruits.sort(function(a, b) {
return a.localeCompare(b);
});
console.log(fruits);
["バナナ", "みかん", "りんご"]
localeCompare は、言葉の並べ替えに適した比較をしてくれます。
6. アロー関数で比較関数をもっと簡単に書く
JavaScriptでは、関数を短く書ける「アロー関数」という書き方があります。先ほどの数字の小さい順の比較関数は、こう書けます。
numbers.sort((a, b) => a - b);
簡単に書けて見やすいので慣れたらぜひ使ってみてください。
7. まとめの代わりに注意点
sortは元の配列を書き換えます。元のデータを残したい場合は、slice()メソッドで配列をコピーしてから使うのがおすすめです。
let numbers = [10, 5, 100, 1];
let sortedNumbers = numbers.slice().sort((a, b) => a - b);
console.log(numbers);
console.log(sortedNumbers);
[10, 5, 100, 1]
[1, 5, 10, 100]
元の配列は変わらず、新しい配列を並べ替えられます。
まとめ
ここまでJavaScriptの配列操作において非常に重要かつ頻繁に利用される「sortメソッド」について詳しく解説してきました。配列の並べ替えは、ウェブアプリケーションの開発において避けては通れない技術の一つです。例えば、ECサイトの商品一覧を価格の安い順に並べたり、SNSの投稿を最新順に表示したりする際には、このソート機能が中心的な役割を担っています。
sortメソッドの特性と挙動の理解
JavaScriptのsort()は非常に強力ですが、初心者の方が最も躓きやすいポイントは「デフォルトでは文字列として比較される」という点です。記事内でも触れた通り、数値の配列に対してそのままsort()を適用すると、[1, 10, 100, 2]といった直感に反する並び順になってしまいます。これはJavaScriptが内部的に各要素を文字列として認識し、Unicodeコードポイントの順序に従って比較を行うためです。
これを解決するためには「比較関数」の指定が不可欠です。比較関数に渡される2つの引数(aとb)の戻り値によって、並び順が決定されます。
- 戻り値が負(a - b < 0): aをbより前に配置(昇順)
- 戻り値が正(a - b > 0): bをaより前に配置(降順)
- 戻り値が0: 順序を変更しない
実践的なサンプルコード:複雑なデータのソート
実際の開発現場では、単純な数値や文字列だけでなく、オブジェクトが含まれた配列を扱うことがほとんどです。例えば、ユーザー情報を持つオブジェクトの配列を、年齢(age)順に並べ替える場合は以下のように記述します。
const users = [
{ name: "田中", age: 25 },
{ name: "佐藤", age: 18 },
{ name: "鈴木", age: 32 },
{ name: "高橋", age: 21 }
];
// 年齢が低い順(昇順)に並べ替え
users.sort((a, b) => {
return a.age - b.age;
});
console.log(users);
[
{ "name": "佐藤", "age": 18 },
{ "name": "高橋", "age": 21 },
{ "name": "田中", "age": 25 },
{ "name": "鈴木", "age": 32 }
]
このように、プロパティにアクセスすることで、オブジェクト形式のデータも自由自在に制御することが可能です。また、大規模なデータを扱う際には、元の配列を破壊しない(副作用を避ける)ために、slice()やスプレッド構文([...array])を使用してコピーを作成してからソートを行う習慣を身につけておくと、デバッグが容易な堅牢なプログラムになります。
エンジニアとしての応用:多角的なソート条件
さらに高度なテクニックとして、複数の条件を組み合わせることも可能です。「まずはスコアの高い順に並べ、スコアが同じ場合は名前のアルファベット順にする」といったロジックも、比較関数の中で条件分岐を記述することで実現できます。JavaScriptの柔軟性を活かして、ユーザーにとって最も使いやすいデータの表示順を追求してみましょう。
生徒
「先生、ありがとうございました!sort()メソッドの仕組みがやっと腑に落ちました。最初、数字が変な順番に並んだときはバグかと思って焦りましたけど、文字列として比較されていたからなんですね。」
先生
「そうなんです。JavaScriptの仕様を知らないと少し驚きますよね。でも比較関数(コールバック関数)の使い方さえマスターしてしまえば、どんなに複雑なデータ形式でも自由自在に並べ替えることができますよ。アロー関数を使った書き方は試してみましたか?」
生徒
「はい!(a, b) => a - b と書くだけで昇順になるので、すごくシンプルで書きやすいです。今まではfunctionって毎回書いていたので、これからは積極的にアロー関数を使っていこうと思います。あ、それから質問なのですが、日本語の五十音順にする時はどうするのがベストですか?」
先生
「鋭い質問ですね!日本語の場合は、記事でも紹介したlocaleCompareを使うのが一番確実です。ひらがなとカタカナが混ざっていても適切に処理してくれますし、ブラウザの言語設定に合わせた自然な並び順を提供してくれます。多言語対応のアプリを作る時にも必須の知識になりますよ。」
生徒
「なるほど、localeCompareですね。覚えておきます!あと、先生が言っていた『元の配列を書き換えてしまう』という注意点も印象的でした。気づかないうちに元のデータを壊しちゃいそうなので、これからはまずコピーを作ってからソートする癖をつけます。」
先生
「その意識は素晴らしいです!『イミュータブル(不変)』な操作を心がけるのは、モダンなフロントエンド開発、特にReactなどのフレームワークを使う際には非常に重要な考え方になります。ぜひこの調子で、配列の他のメソッド、例えばfilterやmapなども組み合わせて使えるよう練習してみてくださいね。」
生徒
「ありがとうございます!次はfilterと組み合わせて、特定の条件に合うものだけを抽出してからソートする処理に挑戦してみます。プログラミングがどんどん楽しくなってきました!」
先生
「その意気です!実際に自分でコードを書いて、コンソールで結果を確認しながら進めるのが上達の近道です。もしエラーが出たり、思い通りの順番にならなかったりしたときは、いつでも相談に乗りますからね。頑張りましょう!」