プログラミング

【PR】を含みます。

【JavaScript】既存のHTML要素をランダムに表示する(並び替える)方法

JavaScriptで既存のHTML要素をランダムに表示する方法

JavaScriptで既存のHTML要素をランダムに表示する(並び替える)方法を解説します。

また、先頭の要素は固定してそれ以外の要素をランダムに表示する方法も解説しています。

ランダムアルゴリズムとして、偏りが少ないといわれているFisher-Yatesを採用してます。

【サンプル】既存のHTML要素をランダムに並び替え

ページを更新するたびに、下記画像がランダムな順番で表示されます。

サンプル1
サンプル2
サンプル3
サンプル4
サンプル5
サンプル6

【実装コード】既存のHTML要素をランダムに並び替え

下記HTML・CSS・JavaSctiptをコピペすることで既存のHTML要素をランダムに表示することができます。

HTML
Copy
  1. <div class="random_box">
  2.   <div class="random_item">
  3.     <img src="image URL" alt="サンプル">
  4.   </div>
  5.   <div class="random_item">
  6.     <img src="image URL" alt="サンプル">
  7.   </div>
  8.   <div class="random_item">
  9.     <img src="image URL" alt="サンプル">
  10.   </div>
  11.   <div class="random_item">
  12.     <img src="image URL" alt="サンプル">
  13.   </div>
  14.   <div class="random_item">
  15.     <img src="image URL" alt="サンプル">
  16.   </div>
  17.   <div class="random_item">
  18.     <img src="image URL" alt="サンプル">
  19.   </div>
  20. </div>
CSS
Copy
  1. .random_box {
  2.   display: flex;
  3.   gap: 30px;
  4.   flex-wrap: wrap;
  5.   padding: 0 20px;
  6. }
  7. .random_item {
  8.   width: calc((100% - 60px) / 3);
  9. }
  10. .random_item img {
  11.   width: 100%;
  12.   height: auto;
  13. }
JavaSctipt
Copy
  1. //読み込み時に実行
  2. shuffleElements();
  3. function shuffleElements() {
  4.   let randomBox = document.querySelectorAll('.random_box');
  5.   // randomBoxがnullまたはundefinedであるかチェック
  6.   if (!randomBox || randomBox === 0) {
  7.     return; // 要素が見つからない場合、関数を終了
  8.   }
  9.   for (let i = 0; i < randomBox.length; i++) {
  10.     let elements = randomBox[i].querySelectorAll('.random_item');
  11.     // elementsがnullまたはundefinedであるかチェック
  12.     if (!elements || elements.length === 0) {
  13.       return; // 要素が見つからない場合、関数を終了
  14.     }
  15.     let elementsArray = Array.from(elements);
  16.     // Fisher-Yatesで配列をランダムに並び替え
  17.     for (let j = elementsArray.length - 1; j > 0; j--) {
  18.       let randomIndex = Math.floor(Math.random() * (j + 1));
  19.       [elementsArray[j], elementsArray[randomIndex]] = [elementsArray[randomIndex], elementsArray[j]];
  20.     }
  21.     // randomBoxをクリア
  22.     while (randomBox[i].firstChild) {
  23.       randomBox[i].removeChild(randomBox[i].firstChild);
  24.     }
  25.     // ランダムに並び替えた要素を再配置
  26.     elementsArray.forEach(function(element) {
  27.       randomBox[i].appendChild(element);
  28.     });
  29.   }
  30. }

【サンプル】先頭のHTML要素は固定して、その他の要素をランダムに並び替え

ページを更新するたびに、先頭の画像(サイコロ1)は固定のままで、それ以外の画像ははランダムな順番で表示されます。

サンプル1
サンプル2
サンプル3
サンプル4
サンプル5
サンプル6

【実装コード】先頭のHTML要素は固定して、その他の要素をランダムに並び替え

下記HTML・CSS・JavaSctiptをコピペすることで先頭のHTML要素は固定して、その他の要素をランダムに並び替えることができます。

HTML
Copy
  1. <div class="fixed_random-box">
  2.   <div class="random_item -fixed">
  3.     <img src="image URL" alt="サンプル">
  4.   </div>
  5.   <div class="random_item">
  6.     <img src="image URL" alt="サンプル">
  7.   </div>
  8.   <div class="random_item">
  9.     <img src="image URL" alt="サンプル">
  10.   </div>
  11.   <div class="random_item">
  12.     <img src="image URL" alt="サンプル">
  13.   </div>
  14.   <div class="random_item">
  15.     <img src="image URL" alt="サンプル">
  16.   </div>
  17.   <div class="random_item">
  18.     <img src="image URL" alt="サンプル">
  19.   </div>
  20. </div>
CSS
Copy
  1. .fixed_random-box {
  2.   display: flex;
  3.   gap: 30px;
  4.   flex-wrap: wrap;
  5.   padding: 0 20px;
  6. }
  7. .random_item {
  8.   width: calc((100% - 60px) / 3);
  9. }
  10. .random_item img {
  11.   width: 100%;
  12.   height: auto;
  13. }
JavaSctipt
Copy
  1. //読み込み時に実行
  2. fixedShuffleElements();
  3. function fixedShuffleElements() {
  4.   let fixedRandomBox = document.querySelectorAll('.fixed_random-box');
  5.   // fixedRandomBoxがnullまたはundefinedであるかチェック
  6.   if (!fixedRandomBox || fixedRandomBox === 0) {
  7.     return; // 要素が見つからない場合、関数を終了
  8.   }
  9.   for (let i = 0; i < fixedRandomBox.length; i++) {
  10.     let elements = fixedRandomBox[i].querySelectorAll('.random_item');
  11.     // elementsがnullまたはundefinedであるかチェック
  12.     if (!elements || elements.length === 0) {
  13.       continue; // 要素が見つからない場合、処理をスキップ
  14.     }
  15.     let elementsArray = Array.from(elements);
  16.     // -fixedクラスを持つ要素を取得
  17.     let fixedElements = elementsArray.filter(function(element) {
  18.       return element.classList.contains('-fixed');
  19.     });
  20.     // -fixedクラスを持つ要素を除いた要素を取得
  21.     let nonFixedElements = elementsArray.filter(function(element) {
  22.       return !element.classList.contains('-fixed');
  23.     });
  24.     // 非固定要素をFisher-Yatesでランダムに並び替え
  25.     for (let j = nonFixedElements.length - 1; j > 0; j--) {
  26.       let randomIndex = Math.floor(Math.random() * (j + 1));
  27.       [nonFixedElements[j], nonFixedElements[randomIndex]] = [nonFixedElements[randomIndex], nonFixedElements[j]];
  28.     }
  29.     // fixedRandomBoxをクリア
  30.     while (fixedRandomBox[i].firstChild) {
  31.       fixedRandomBox[i].removeChild(fixedRandomBox[i].firstChild);
  32.     }
  33.     // 固定要素を先頭に、それ以外の要素を後ろに配置
  34.     fixedElements.forEach(function(element) {
  35.       fixedRandomBox[i].appendChild(element);
  36.     });
  37.     nonFixedElements.forEach(function(element) {
  38.       fixedRandomBox[i].appendChild(element);
  39.     });
  40.   }
  41. }

アルゴリズムを学びたい方におすすめの1冊

アイコン画像

もみじ

アルゴリズムとそれを支える数学について基礎から学びたい人にオススメの一冊です。

HTMLとCSSの知識がありJavaScriptを学びたいという方におすすめの1冊

アイコン画像

もみじ

HTMLとCSSの知識がありJavaScriptを学びたいという方に入門書としておすすめの書籍です。

実務で役立つサンプルを手を動かしながら学ぶことができ、実践的なスキルを身に付けることができます。

JavaScriptのフロントエンドエンジニアを目指している方におすすめの1冊

アイコン画像

もみじ

この本はJavaScript初心者からフロントエンドエンジニアを目指す方にぴったりの1冊です。

非同期処理やAJAXなど、現代の開発で必要なスキルがわかりやすく解説されており、実務で役立つスキルを学ぶことができます。

-プログラミング
-