本篇文章给大家带来的内容是关于如何使用纯CSS实现条纹错觉的动画效果(附源码),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。
效果预览
源代码下载
https://github.com/comehope/front-end-daily-challenges
代码解读
定义 dom,容器中包含 2 个元素,分别代表 2 条轨道:
<div class="container"> <span class='track'></span> <span class='track'></span> </div>
居中显示:
body { margin: 0; height: 100vh; display: flex; align-items: center; justify-content: center; background-color: #999; }
定义容器尺寸和子元素的布局方式:
.container { font-size: 30px; width: calc(13em + 0.5em); height: 8em; display: flex; flex-direction: column; justify-content: space-between; }
定义 2 个色值,一个亮的和一个暗的:
.container { --dark: #222; --light: #ddd; }
画出 2 条轨道的轮廓:
.track { width: inherit; height: 2em; border: 1px solid var(--dark); }
为 2 条轨道的背景图案,图案是明暗相间的条纹,但第 2 条轨道要错半个格:
.track { background: linear-gradient( 90deg, var(--dark) 50%, var(--light) 50% ); background-size: 1em; } .track:nth-child(2) { background-position: 0.5em; }
用伪元素画出 2 个矩形:
.track { position: relative; display: flex; align-items: center; } .track::before { content: ''; position: absolute; width: 2em; height: 0.8em; background-color: var(--light); }
让这 2 个矩形在轨道上往复移动:
.track::before { animation: move 5s linear infinite alternate; } @keyframes move { from { left: 0; } to { left: calc(100% - 2em); } }
此时,两个矩形看起来是一先一后地前进的,但实际上它们是在同一时刻开始并且以相同的速度在移动。接下来我们来揭秘真相。
在 dom 中增加一个子元素,作为按钮;
<p class="container"> <span class='track'></span> <span class='track'></span> <span class="toggle">Show me the truth</span> </p>
设置按钮的样式:
.toggle { order: -1; width: 10em; height: 2em; border: 2px solid var(--dark); border-radius: 0.2em; font-size: 0.5em; font-family: sans-serif; font-weight: bold; color: black; text-align: center; line-height: 2em; cursor: pointer; user-select: none; }
为按钮设置与轨道风格类似的背景,以及鼠标悬停效果:
.toggle { background-image: linear-gradient(to right, #ddd 50%, #999 50%); background-size: 1em; transition: 0.5s; } .toggle:hover { background-position: 5em; }
增加一段点击按钮时触发的脚本,为轨道元素切换样式:
let $toggle = document.getElementsByClassName('toggle')[0] let $tracks = Array.from(document.getElementsByClassName('track')) $toggle.addEventListener('click', function() { $tracks.forEach(track => track.classList.toggle('highlights')) })
终于,谜底就在切换样式之后被揭晓了:
.track::before { box-sizing: border-box; border: solid var(--dark); border-width: 0; } .track.highlights::before { background-color: white; border-width: 0.1em; }
大功告成!
相关推荐:
Atas ialah kandungan terperinci 如何使用纯CSS实现条纹错觉的动画效果(附源码). Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kursor adat dengan CSS adalah hebat, tetapi kita boleh mengambil sesuatu ke peringkat seterusnya dengan JavaScript. Menggunakan JavaScript, kita boleh beralih antara negeri kursor, letakkan teks dinamik dalam kursor, gunakan animasi kompleks, dan gunakan penapis.

Animasi CSS interaktif dengan unsur -unsur yang menghilangkan satu sama lain kelihatan lebih masuk akal pada tahun 2025. Walaupun tidak perlu untuk melaksanakan pong dalam CSS, peningkatan fleksibiliti dan kuasa CSS mengukuhkan kecurigaan Lee '

Petua dan cara untuk menggunakan harta penapis latar belakang CSS ke antara muka pengguna gaya. Anda akan belajar bagaimana untuk meletakkan penapis latar belakang di antara pelbagai elemen, dan mengintegrasikannya dengan kesan grafik CSS yang lain untuk membuat reka bentuk yang rumit.

Nah, ternyata ciri-ciri animasi terbina dalam SVG ' s tidak pernah ditamatkan seperti yang dirancang. Pasti, CSS dan JavaScript lebih mampu membawa beban, tetapi ia baik untuk mengetahui bahawa SMIL tidak mati di dalam air seperti sebelumnya

Yay, let ' s melompat untuk teks-wrap: Pretty Landing dalam Pratonton Teknologi Safari! Tetapi berhati -hatilah bahawa ia ' s berbeza dari bagaimana ia berfungsi dalam pelayar kromium.

Kemas kini trik CSS ini menyoroti kemajuan yang ketara dalam almanak, penampilan podcast baru-baru ini, panduan kaunter CSS baru, dan penambahan beberapa penulis baru yang menyumbang kandungan berharga.

Kebanyakan masa, orang mempamerkan ciri-ciri Tailwind ' Apabila dipamerkan dengan cara ini, @apply tidak menjanjikan sama sekali. Jadi obvio

Menggunakan seperti idiot datang ke ketidakcocokan antara alat yang anda gunakan untuk menggunakan dan ganjaran dalam kerumitan dikurangkan berbanding kerumitan yang ditambah.


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

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

SublimeText3 Linux versi baharu
SublimeText3 Linux versi terkini

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

MinGW - GNU Minimalis untuk Windows
Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma
