カテゴリ: JavaScript 更新日: 2026/03/13

JavaScriptの配列の並べ替え(sortメソッド)の基本とカスタマイズ

JavaScriptの配列の並べ替え(sortメソッド)の基本とカスタマイズ
JavaScriptの配列の並べ替え(sortメソッド)の基本とカスタマイズ

先生と生徒の会話形式で理解しよう

生徒

「先生、JavaScriptで配列の中身を並べ替えたいんですけど、どうやったらいいですか?」

先生

「配列を並べ替えるなら、sortメソッドを使います。これを使うと、文字や数字を簡単に順番に並べることができますよ。」

生徒

「でも、自分の好きな順番に並べることもできますか?」

先生

「もちろんです!基本の使い方から、カスタマイズの方法まで一緒に見ていきましょう!」

1. sortメソッドとは?基本的な使い方

1. sortメソッドとは?基本的な使い方
1. sortメソッドとは?基本的な使い方

JavaScriptで配列のデータを特定のルールで並べ替えたいときに欠かせないのがsortメソッドです。例えば、名簿を名前順に並べたり、商品の価格を安い順に並べたりするときに非常によく使われます。

プログラミング未経験の方でもイメージしやすいように、まずは「果物の名前」をバラバラに用意して、それを五十音順(正しくはUnicode順)に整列させるサンプルを見てみましょう。


// 並べ替えたい元の配列を作成
let fruits = ["りんご", "バナナ", "みかん"];

// sortメソッドを実行して並べ替える
fruits.sort();

// 結果をコンソールに表示
console.log(fruits);

["バナナ", "みかん", "りんご"]

上記のコードを実行すると、配列の中身が自動的に並べ替えられます。ここで不思議に思うかもしれませんが、JavaScriptの標準的なsortは、文字を「Unicode(ユニコード)」というコンピュータ上の背番号のようなルールに従って比較します。

そのため、今回の例では「バ(は)→み→り」という順番で出力されました。このように、sort()と書くだけで、配列の中身を特定の規則に沿って整列させることができるのです。

基本的には「文字を基準に並べ替える機能」だと覚えておくと、この後の学習がスムーズになりますよ。

2. 数字の配列をsortで並べ替えるときの落とし穴と注意点

2. 数字の配列を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. 比較関数で数字の並べ替えをカスタマイズする

3. 比較関数で数字の並べ替えをカスタマイズする
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. 比較関数で数字を大きい順に並べる方法

4. 比較関数で数字を大きい順に並べる方法
4. 比較関数で数字を大きい順に並べる方法

同じようにして、大きい順に並べたいときはとbを入れ替えて計算します。


let numbers = [10, 5, 100, 1];

numbers.sort(function(a, b) {
  return b - a;
});

console.log(numbers);

[100, 10, 5, 1]

これで数字を大きい順に並べることができました。

5. 文字列の並べ替えも比較関数でカスタマイズできる

5. 文字列の並べ替えも比較関数でカスタマイズできる
5. 文字列の並べ替えも比較関数でカスタマイズできる

文字列も比較関数で好きな順番に並べ替えられます。日本語やアルファベットの順番を正しく比較するために localeCompare という便利な関数を使います。


let fruits = ["バナナ", "りんご", "みかん"];

fruits.sort(function(a, b) {
  return a.localeCompare(b);
});

console.log(fruits);

["バナナ", "みかん", "りんご"]

localeCompare は、言葉の並べ替えに適した比較をしてくれます。

6. アロー関数で比較関数をもっと簡単に書く

6. アロー関数で比較関数をもっと簡単に書く
6. アロー関数で比較関数をもっと簡単に書く

JavaScriptでは、関数を短く書ける「アロー関数」という書き方があります。先ほどの数字の小さい順の比較関数は、こう書けます。


numbers.sort((a, b) => a - b);

簡単に書けて見やすいので慣れたらぜひ使ってみてください。

7. まとめの代わりに注意点

7. まとめの代わりに注意点
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などのフレームワークを使う際には非常に重要な考え方になります。ぜひこの調子で、配列の他のメソッド、例えばfiltermapなども組み合わせて使えるよう練習してみてくださいね。」

生徒

「ありがとうございます!次はfilterと組み合わせて、特定の条件に合うものだけを抽出してからソートする処理に挑戦してみます。プログラミングがどんどん楽しくなってきました!」

先生

「その意気です!実際に自分でコードを書いて、コンソールで結果を確認しながら進めるのが上達の近道です。もしエラーが出たり、思い通りの順番にならなかったりしたときは、いつでも相談に乗りますからね。頑張りましょう!」

カテゴリの一覧へ
新着記事
New1
JavaScript
JavaScriptの条件式で論理演算子(&&, ||, !)を活用する方法!初心者でもわかる使い方ガイド
New2
TypeScript
TypeScriptでエラー処理を共通関数化して効率的に開発しよう!初心者向け例外処理ガイド
New3
JavaScript
JavaScriptの条件式における比較演算子の使い方まとめ!初心者でもわかる基本ルールと活用法
New4
JavaScript
JavaScriptのswitch文の基本構文と使いどころを学ぼう!初心者でもわかる条件分岐の書き方
人気記事
No.1
Java&Spring記事人気No1
JavaScript
JavaScriptのインストール方法まとめ!Windows・Mac・Linux別にステップ解説
No.2
Java&Spring記事人気No2
JavaScript
JavaScriptのtoStringとString関数の違いを初心者向けに解説
No.3
Java&Spring記事人気No3
TypeScript
TypeScriptでコメントを書く正しい書き方と使い分け【初心者向けにやさしく解説】
No.4
Java&Spring記事人気No4
JavaScript
JavaScriptで統一感のあるコードを書くための基本ルール完全ガイド初心者向けコーディング規約入門
No.5
Java&Spring記事人気No5
JavaScript
JavaScriptのonclick・onchangeなどの基本イベントを理解しよう
No.6
Java&Spring記事人気No6
JavaScript
JavaScriptプログラムの実行方法まとめ!ブラウザ・Node.js・コンソールの使い方
No.7
Java&Spring記事人気No7
TypeScript
TypeScriptのnever型を使ったエラーハンドリング!例外処理を極める安全なコードの書き方
No.8
Java&Spring記事人気No8
JavaScript
JavaScriptでクエリパラメータを取得する方法を完全解説 URLSearchParamsの使い方を初心者向けに丁寧に説明