การสลับสไตล์การเปิดใช้งานด้วย JavaScript
ในบทเรียนที่ผ่านมาเราเรียนรู้วิธีการเปิดใช้งาน เซลล์โดยการคลิกที่เซลล์นั้น ทีนี้มาทำให้ เกิดการสลับสีกัน: ให้เซลล์แรกถูกเติมสีแดง, เซลล์ที่สอง - เขียว, เซลล์ที่สาม - เป็นสีแดงอีกครั้งและต่อไปเรื่อยๆ
เพื่อแก้ปัญหานี้เราต้องการ คลาส CSS สองคลาส:
.color1 {
background: red;
}
.color2 {
background: green;
}
มาลองทำให้เกิดการสลับที่อธิบายไว้:
let tds = document.querySelectorAll('#table td');
let color = 'color1';
for (let td of tds) {
td.addEventListener('click', function() {
if (color == 'color1') {
color = 'color2'
} else {
color = 'color1'
}
this.classList.add(color);
});
}
ศึกษาโค้ดของฉัน จากนั้นลองแก้ปัญหา นี้ด้วยตัวเองซ้ำอีกครั้ง
การสลับหลายสีจากอาร์เรย์
สมมติว่าตอนนี้เราต้องการสลับไม่ใช่แค่สองสี แต่เป็นจำนวนเท่าใดก็ได้ ลองเก็บอาร์เรย์ของคลาส CSS เพื่อสิ่งนี้:
let colors = ['color1', 'color2', 'color3'];
ลองกำหนดสีของคลาสของเรา:
.color1 {
background: red;
}
.color2 {
background: green;
}
.color3 {
background: yellow;
}
ตอนนี้มาทำให้เกิดการสลับ:
let tds = document.querySelectorAll('#table td');
let i = 0;
let colors = ['color1', 'color2', 'color3'];
for (let td of tds) {
td.addEventListener('click', function() {
this.classList.add(colors[i]);
i++;
if (i == colors.length) {
i = 0;
}
});
}
อธิบายว่าโค้ดของฉันที่นำเสนอนั้นทำงานอย่างไร