Saya menghadapi isu Flickity dengan mengakses gaya menggunakan js, khususnya, gaya untuk titik penunjuk. Saya mahu mata diwarnakan berdasarkan warna dalam tatasusunan (dalam projek saya ini harus menjadi tatasusunan dinamik, tetapi pada masa ini statik untuk memudahkan kes ujian). Fungsi saya berfungsi pada elemen dengan nama kelas yang sama dengan titik penunjuk yang saya letakkan dalam html di bawah karusel Flickity.
Ini adalah forked (dari dokumentasi Flickity) dan menukar CodePen untuk menggambarkan masalah saya:
https://codepen.io/Insa-Deist/pen/jOXNOKM
Terima kasih terlebih dahulu untuk sebarang petua.
Js yang saya tambahkan sepatutnya betul, saya telah mencubanya pada baris titik lain yang tiada dalam bekas karusel Flickity dan mempunyai nama kelas yang sama yang dibicarakan oleh js (apabila saya membuka kod sumber saya project , titik isyarat juga mempunyai nama kelas yang sama).
*Baru sahaja mendapat amaran yang meminta saya menampal kod di sini juga, jadi saya menampalnya di sini:
html
Flickity - freeScroll, wrapAround
baris titik untuk menunjukkan fungsi js dengan tatasusunan warna --> kelas yang diberikan apabila saya membuka kod sumber projek saya
css
/* css luaran: flickity.css */ * { saiz kotak: kotak sempadan; } badan { font-family: sans-serif; } .carousel { latar belakang: #FAFAFA; } .carousel-cell { lebar: 66%; ketinggian: 200px; jidar kanan: 10px; latar belakang: #8C8; jejari sempadan: 5px; kenaikan balas: sel karusel; } /* nombor sel */ .carousel-cell:sebelum { paparan: blok; text-align: tengah; kandungan: kaunter(sel karusel); ketinggian garis: 200px; saiz fon: 80px; warna: putih; } .dot { paparan: inline-block; lebar: 10px; ketinggian: 10px; jidar: 0 8px; jejari sempadan: 50%; kelegapan: 1; kursor: penunjuk; } .flickity-page-dots .dot{ kelegapan: 1; } .flickity-page-dots .dot.is-selected { -webkit-filter: blur(3px); -moz-filter: blur(3px); -o-penapis: blur(3px); -ms-filter: blur(3px); penapis: blur(3px);}js
// js luaran: flickity.pkgd.js warna var = ["#e57373", "#ba68c8", "#90caf9", "#4db6ac", "#dce775", "#ffb74d", "#b0bec5", "#FF69B4"]; var customizeContainer = Array.from(document.querySelectorAll('.dot')); customizeContainer.forEach(fungsi(nod, i) { node.style.background = warna[i % warna.panjang]; });
Cuba di codepen: