先寫一個簡單的 html 頁面出來
<style>
/* ... */
</style>
<ul>
<li>html</li>
<li>css</li>
<li>js</li>
</ul>
通過 Math.random()
屬性可以隨機生成一個數字,然後通過轉化為十六進制的方法進行處理,下面就是隨機生成 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>
如果有更好的寫法,歡迎評論!