まずはシンプルな 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
です。
次に、この色を上記の 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
を使用してイベントを書き込み、すべてのコードをまとめます。
効果を見てみましょう。
これらをコピーしてローカルで実行すれば、効果を見ることができます。
<!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>
より良い書き方があれば、コメントを歓迎します!