dan mouseenter
. Walaupun berfungsi, penyelesaian CSS tulen sering lebih baik. Artikel ini memperincikan pendekatan CSS sahaja, yang pada mulanya diilhamkan oleh teknik yang digunakan dalam mencipta semula animasi seperti laman utama Netflix. Walau bagaimanapun, percubaan sebelumnya menggunakan kaedah ini gagal pada susun atur berasaskan grid kerana jurang antara unsur-unsur. Artikel ini membentangkan penyelesaian yang elegan mengendalikan jurang ini. mouseleave
HTML asas menggunakan senarai berasaskan grid:
- : grid kontena.
.grid
- : item grid individu.
.grid__child
.grid { display: grid; grid-template-columns: repeat(auto-fit, 15rem); grid-gap: 1rem; } .grid__child { background: rgba(0, 0, 0, .1); border-radius: .5rem; aspect-ratio: 1/1; }Ini mewujudkan grid tiga lajur (menyesuaikan secara dinamik berdasarkan saiz skrin) dengan jurang antara item.
memanfaatkan pemilih CSS
Interaksi teras melibatkan dua langkah:
- melayang bekas mempengaruhi semua kanak -kanak.
- kanak -kanak yang melayang itu sendiri dikecualikan.
.grid:hover .grid__child { /* ... */ }Seterusnya, kami mengecualikan kanak -kanak yang sedang berlegar menggunakan
untuk mengurangkan kelegapan: :not(:hover)
.grid:hover .grid__child:not(:hover) { opacity: 0.3; }Ini berfungsi dengan sempurna tanpa jurang antara unsur -unsur. Walau bagaimanapun, dengan jurang, kesannya mencetuskan walaupun kursor berada di atas jurang itu sendiri.
Menangani jurang
Penyelesaiannya terletak pada peristiwa penunjuk mengawal. Dengan menetapkan
pada bekas pointer-events: none
dan .grid
pada anak -anaknya, kami memastikan kesan hover hanya mencetuskan apabila secara langsung ke atas elemen kanak -kanak, dengan berkesan mengabaikan jurang.
pointer-events: auto
.grid { /* ... */ pointer-events: none; } .grid__child { /* ... */ pointer-events: auto; }
CSS akhir yang menggabungkan penyelesaian ini ialah:
Batasan Potensi
.grid { display: grid; grid-template-columns: repeat(auto-fit, 15rem); grid-gap: 3rem; pointer-events: none; } .grid:hover .grid__child:not(:hover) { opacity: 0.3; } .grid__child { background: rgba(0, 0, 0, .1); border-radius: .5rem; aspect-ratio: 1/1; pointer-events: auto; transition: opacity 300ms; }
Walaupun berkesan, pendekatan ini mungkin memerlukan pelarasan untuk bekas scrollable (mis., Slider mendatar). Dalam kes sedemikian, membungkus
dalam bekas lain boleh menjadi penyelesaian.
.grid
Kesimpulan
Ini menunjukkan penyelesaian CSS tulen yang kuat untuk cabaran interaksi yang sama. Dengan memanfaatkan pemilih CSS lanjutan dan kawalan acara penunjuk, kami mencapai kesan yang canggih tanpa menggunakan JavaScript, yang membawa kepada kod yang lebih bersih dan lebih diselenggara. Ini menonjolkan keupayaan CSS yang semakin meningkat dan menggalakkan meneroka penyelesaian asli sebelum menambah kerumitan JavaScript.
Atas ialah kandungan terperinci Kesan fokus galeri CSS tulen dengan: tidak. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

CSS Grid adalah alat yang berkuasa untuk mewujudkan susun atur web yang rumit dan responsif. Ia memudahkan reka bentuk, meningkatkan kebolehcapaian, dan menawarkan lebih banyak kawalan daripada kaedah yang lebih lama.

Artikel membincangkan CSS Flexbox, kaedah susun atur untuk penjajaran yang cekap dan pengedaran ruang dalam reka bentuk responsif. Ia menerangkan penggunaan Flexbox, membandingkannya dengan grid CSS, dan butiran sokongan penyemak imbas.

Artikel ini membincangkan teknik untuk membuat laman web responsif menggunakan CSS, termasuk tag Meta Viewport, grid fleksibel, media cecair, pertanyaan media, dan unit relatif. Ia juga meliputi menggunakan grid CSS dan Flexbox bersama -sama dan mengesyorkan rangka kerja CSS

Artikel ini membincangkan harta saiz kotak CSS, yang mengawal bagaimana dimensi elemen dikira. Ia menerangkan nilai seperti kotak kandungan, kotak sempadan, dan kotak padding, dan kesannya terhadap reka bentuk susun atur dan penjajaran bentuk.

Artikel membincangkan membuat animasi menggunakan CSS, sifat utama, dan menggabungkan dengan JavaScript. Isu utama adalah keserasian penyemak imbas.

Artikel membincangkan menggunakan CSS untuk transformasi 3D, sifat utama, keserasian penyemak imbas, dan pertimbangan prestasi untuk projek web. (Kira -kira aksara: 159)

Artikel ini membincangkan menggunakan kecerunan CSS (linear, radial, mengulangi) untuk meningkatkan visual laman web, menambah kedalaman, fokus, dan estetika moden.

Artikel membincangkan unsur-unsur pseudo dalam CSS, penggunaannya dalam meningkatkan gaya HTML, dan perbezaan dari kelas pseudo. Menyediakan contoh praktikal.


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa
