Rumah hujung hadapan web tutorial css Web-linger.css: Seperti wow.js tetapi dengan animasi tatal CSS-y

Web-linger.css: Seperti wow.js tetapi dengan animasi tatal CSS-y

Mar 07, 2025 pm 05:05 PM

Web-Slinger.css: Like Wow.js But With CSS-y Scroll Animations

Artikel ini meneroka animasi tatal, khususnya memberi tumpuan kepada "tatal yang mencetuskan" -a teknik di mana animasi mengaktifkan sekali pengguna skrol melewati titik tertentu. Walaupun kini tidak mempunyai sokongan CSS asli, kami dapat mencapai kesan ini menggunakan teknik CSS yang bijak, mewujudkan alternatif CSS sahaja untuk perpustakaan JavaScript seperti wow.js. Pendekatan ini menggunakan harta

, sifat tersuai, dan pertanyaan gaya. animation-timeline

Penyelesaian animasi tatal yang sedia ada sering membalikkan animasi ketika menatal ke atas, tidak seperti tingkah laku "satu-dan-dilakukan" yang diingini yang dilihat di wow.js. Batasan ini mengilhami penciptaan "Web-Slinger.css," perpustakaan CSS tulen meniru fungsi wow.js.

web-slinger.css: Perpustakaan animasi tatal CSS sahaja

web-slinger.css menggunakan kelas seperti

dan .scroll-trigger-n, bersama-sama dengan sifat tersuai (.on-scroll-trigger-n), untuk menguruskan animasi. Pendekatan ini menghancurkan animasi mencetuskan dari elemen animasi, memberikan fleksibiliti. --scroll-trigger-n

Contoh mudah menggunakan

untuk mencetuskan animasi "flipiny" dari animate.css. Contoh yang lebih kompleks, seperti "cownter" dalam demo, menunjukkan mencetuskan pelbagai animasi dari titik tatal tunggal. .scroll-trigger-8

markup cownter adalah mudah:

<div>
  <h2></h2>
  <div>
    <br><br><a href="https://www.php.cn/link/93ac0c50dd620dc7b88e5fe05c70e15b">? Play again</a>
  </div>
</div>
Salin selepas log masuk
dan CSS memanfaatkan pertanyaan gaya untuk kemas kini kandungan dinamik:

.header {
  .cownter::after {
    --cownter: calc(var(--scroll-trigger-2) + var(--scroll-trigger-4) + var(--scroll-trigger-8) + var(--scroll-trigger-11));
    --pluralised-cow: 'cows';
    counter-set: cownter var(--cownter);
    content: "Have " counter(cownter) " " var(--pluralised-cow) ", man";
  }

  @container style(--scroll-trigger-2: 1) and style(--scroll-trigger-4: 0) {
    .cownter::after {
      --pluralised-cow: 'cow';
    }
  }

  a {
    text-decoration: none;
    color: blue;
  }
}

:root:has(.reset:active) * {
  animation-name: none;
}
Salin selepas log masuk
Demo menggunakan web-slinger.css sebagai sumber luaran.

Butiran pelaksanaan web-slinger.css

Konsep teras melibatkan penggunaan

sebagai garis masa animasi untuk mencipta elemen tetap tetap. Pertanyaan gaya dan sifat tersuai kemudian mengawal animasi lain berdasarkan penglihatan elemen tetap ini. view()

Teknik ini menghindari secara langsung menghidupkan elemen-elemen yang kelihatan pengguna, sebaliknya menggunakan elemen tetap sebagai pencetus. Dinamakan Paparan Masa Kemajuan () menghubungkan elemen tetap ke unsur -unsur yang akan dianimasi.

timeline-scope

Lihat kod CSS

/** Each trigger element toggles `--scroll-trigger-n` from 0 to 1, unpausing animations on `.on-scroll-trigger-n` **/
:root {
  animation-name: run-scroll-trigger-1, run-scroll-trigger-2 /*etc*/;
  animation-duration: 1ms;
  animation-fill-mode: forwards;
  animation-timeline: --trigger-timeline-1, --trigger-timeline-2 /*etc*/;
  timeline-scope: --trigger-timeline-1, --trigger-timeline-2 /*etc*/;
}

@property --scroll-trigger-1 {
  syntax: "<integer>";
  initial-value: 0;
  inherits: true;
}
@keyframes run-scroll-trigger-1 {
  to { --scroll-trigger-1: 1; }
}

/** Animate elements only when `.scroll-trigger-1` is in view **/
.on-scroll-trigger-1 { animation-play-state: paused; }
@container style(--scroll-trigger-1: 1) { .on-scroll-trigger-1 { animation-play-state: running; } }

/** Trigger element, fixed to top, activating animations **/
.scroll-trigger-1 { view-timeline-name: --trigger-timeline-1; }</integer>
Salin selepas log masuk

Batasan dan Penambahbaikan Masa Depan

Web-slinger.css, sementara berfungsi, menghasilkan fail CSS yang lebih besar dengan lebih banyak pencetus. Nama kelas bernombor tidak mempunyai kejelasan semantik. Sebaik -baiknya, sokongan penyemak imbas asli akan membolehkan menghubungkan pencetus dan sasaran menggunakan ID, sama dengan atribut hipotesis.

Masa depan animasi yang dicetuskan tatal terletak pada sokongan penyemak imbas asli. Pendekatan deklaratif yang serupa dengan web-slinger.css boleh digunakan untuk penyeragaman.

Atas ialah kandungan terperinci Web-linger.css: Seperti wow.js tetapi dengan animasi tatal CSS-y. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Vue 3 Vue 3 Apr 02, 2025 pm 06:32 PM

Ia &#039; s! Tahniah kepada pasukan Vue untuk menyelesaikannya, saya tahu ia adalah usaha besar dan lama datang. Semua dokumen baru juga.

Sedikit di CI/CD Sedikit di CI/CD Apr 02, 2025 pm 06:21 PM

Saya &#039;

Bolehkah anda mendapatkan nilai harta CSS yang sah dari penyemak imbas? Bolehkah anda mendapatkan nilai harta CSS yang sah dari penyemak imbas? Apr 02, 2025 pm 06:17 PM

Saya mempunyai seseorang yang menulis dengan soalan yang sangat legit ini. Lea hanya blog tentang bagaimana anda boleh mendapatkan sifat CSS yang sah dari penyemak imbas. That &#039; s seperti ini.

Menggunakan Markdown dan Penyetempatan di Editor Blok WordPress Menggunakan Markdown dan Penyetempatan di Editor Blok WordPress Apr 02, 2025 am 04:27 AM

Jika kita perlu menunjukkan dokumentasi kepada pengguna secara langsung dalam editor WordPress, apakah cara terbaik untuk melakukannya?

Kad yang disusun dengan kedudukan melekit dan sasaran sass Kad yang disusun dengan kedudukan melekit dan sasaran sass Apr 03, 2025 am 10:30 AM

Pada hari yang lain, saya melihat sedikit ini sangat indah dari laman web Corey Ginnivan di mana koleksi kad timbunan di atas satu sama lain semasa anda menatal.

Membandingkan penyemak imbas untuk reka bentuk responsif Membandingkan penyemak imbas untuk reka bentuk responsif Apr 02, 2025 pm 06:25 PM

Terdapat beberapa aplikasi desktop ini di mana matlamat menunjukkan laman web anda pada dimensi yang berbeza pada masa yang sama. Oleh itu, anda boleh menulis

Cara menggunakan grid CSS untuk tajuk dan kaki melekit Cara menggunakan grid CSS untuk tajuk dan kaki melekit Apr 02, 2025 pm 06:29 PM

CSS Grid adalah koleksi sifat yang direka untuk menjadikan susun atur lebih mudah daripada yang pernah berlaku. Seperti apa -apa, ada sedikit keluk pembelajaran, tetapi grid adalah

Fon Font Google Fon Fon Font Google Fon Apr 09, 2025 am 10:42 AM

Saya melihat Font Google melancarkan reka bentuk baru (tweet). Berbanding dengan reka bentuk besar yang terakhir, ini terasa lebih berulang. Saya hampir tidak dapat memberitahu perbezaannya

See all articles