⊗jsPmPrASA 485 of 505 menu

การสลับสไตล์การเปิดใช้งานด้วย 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; } }); }

อธิบายว่าโค้ดของฉันที่นำเสนอนั้นทำงานอย่างไร

ไทย
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuမြန်မာNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣTürkmenTürkçeЎзбекOʻzbekTiếng Việt
เราใช้คุกกี้สำหรับการทำงานของเว็บไซต์ การวิเคราะห์ และการปรับเนื้อหาให้เหมาะสมส่วนบุคคล การประมวลผลข้อมูลเกิดขึ้นตาม นโยบายความเป็นส่วนตัว.
ยอมรับทั้งหมด ปรับแต่ง ปฏิเสธ