zishu's blog

zishu's blog

一个热爱生活的博主。https://zishu.me

jsを使用して背景色をランダムに生成する

まずはシンプルな HTML ページを作成します。

<style>
  /* ... */
</style>

<ul>
  <li>html</li>
  <li>css</li>
  <li>js</li>
</ul>

Math.random()プロパティを使用してランダムな数字を生成し、それを 16 進数に変換する方法で処理します。以下は 6 桁の数字をランダム生成するコードと変換するコードです。

const randomHex = () => `#${Math.floor(Math.random() * 0xffffff).toString(16).padEnd(6, "0")}`;

コンソールに出力して結果を確認できます。ランダムに生成された結果は#62113bです。

image

次に、この色を上記の li タグに渡す必要があります。まず、すべての li をループして配列を生成します。for ループを使用してループ処理を行います。

var arr = document.getElementsByTagName('li'), temp = [];
for (var i = 0; i < arr.length; i++) {
  temp.push(arr[i].innerHTML);
}

次に、配列をループ処理し、各 li タグでランダムに生成された色を実行し、自身に渡します。同様に for ループを使用して操作します。

var li = document.getElementsByTagName("li");
for (var i = 0; i < li.length; i++) {
  
  for (var num = 0; num < li.length; num++) {
    li[num].style.background = randomHex();
  }

}

これらのイベントはページの読み込みが完了した後に実行されるため、window.onloadを使用してイベントを書き込み、すべてのコードをまとめます。

効果を見てみましょう。

image

これらをコピーしてローカルで実行すれば、効果を見ることができます。

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width, initial-scale=1.0">
  <title>ランダム生成色</title>
  <style>
    body {
      display: flex;
      justify-content: center;
      padding-top: 100px;
    }
    ul {
      list-style: none;
      padding: 0;
      display: flex;
    }
    li {
      width: 100px;
      height: 40px;
      color: #333;
      display: flex;
      justify-content: center;
      align-items: center;
      margin-right: 30px;
    }
  </style>
</head>
<body>
  <ul>
    <li>html</li>
    <li>css</li>
    <li>js</li>
  </ul>
  <script>
    const randomHex = () => `#${Math.floor(Math.random() * 0xffffff).toString(16).padEnd(6, "0")}`;
    console.log(randomHex());

    var arr = document.getElementsByTagName('li'), temp = [];
    for (var i = 0; i < arr.length; i++) {
      temp.push(arr[i].innerHTML);
    }

    window.onload = function () {
      var li = document.getElementsByTagName("li");
      for (var i = 0; i < li.length; i++) {
        
        for (var num = 0; num < li.length; num++) {
          li[num].style.background = randomHex();
        }

      }
    }
  </script>
</body>
</html>

より良い書き方があれば、コメントを歓迎します!

読み込み中...
文章は、創作者によって署名され、ブロックチェーンに安全に保存されています。