cari
Rumahhujung hadapan webtutorial cssBar pemasa di CSS dengan sifat tersuai

Bar pemasa di CSS dengan sifat tersuai

Baru -baru ini saya perlu melaksanakan pemasa yang kelihatan dalam projek ini, dan sudah ada reka bentuk UI pemasa yang sama dalam projek itu sebagai rujukan. Pengguna tidak perlu melihat nombor berkurangan, tetapi ingin melihat "bar" secara beransur -ansur berkurangan dari penuh ke kosong. Saya menyebut ini kerana terdapat banyak cara untuk melaksanakan UI "pemasa". Artikel ini bukan mengenai semua kaedah ini (hasil carian pada codepen akan lebih membantu), tetapi sebaliknya tentang satu yang berfungsi dengan baik untuk saya.

Jenis pemasa yang saya perlukan adalah apa yang dipanggil bar "giliran masa" dalam projek. Melaksanakan tindakan boleh mencetuskan masa giliran, dan kebanyakan tindakan berikutnya akan disekat sehingga akhir masa giliran. Oleh itu, pemasa bar merah yang jelas adalah pilihan UI yang betul. Ia memberi orang rasa irama dan aliran, anda boleh "merasakan" masa akhir pemasa dan menjadualkan operasi seterusnya anda.

Menetapkan pemasa ini agak mudah ...

Mari buat struktur elemen ibu bapa/kanak -kanak sekiranya kita perlu gaya bahagian kosong bekas pada masa akan datang.

<div>
  <div></div>
</div>

Sekarang, kita hanya gaya bar dalaman.

 .Round-Time-Bar Div {
  Ketinggian: 5px;
  Latar Belakang: Linear-Gradient (ke bawah, merah, #900);
}

Ini memberi kita bar merah yang bagus yang boleh digunakan sebagai penunjuk masa.

Seterusnya, kita perlu membiarkannya dikira, tetapi di sini kita perlu mempertimbangkan fungsi. Pemasa semacam itu perlu tahu berapa lama masa yang diperlukan! Kami boleh memberikan maklumat ini secara langsung dalam HTML. Ini tidak bermakna kita mengelakkan menggunakan JavaScript - kita memeluknya . Kami berkata, "Hei, JavaScript, tolong beri kami pemboleh ubah tempoh dan kami akan mengendalikan yang lain."

<div style="--duration: 5;">
  <div></div>
</div>

Malah, pendekatan ini sangat sesuai untuk pengendalian DOM moden JavaScript. Selagi- --variable adalah betul, ia boleh menjadikan semula elemen DOM pada bila-bila masa, dan kami dapat memastikan reka bentuk mengendalikan keadaan ini dengan baik. Kami akan membuat variasi seperti ini.

Sekarang, mari kita mulakan animasi. Berita baiknya, ia mudah. Ini adalah kerangka utama baris:

 @KeyFrames Roundtime {
  ke {
    /* Lebih efisien daripada animasi `lebar`*/
    Transform: Scalex (0);
  }
}

Kita boleh "memampatkan" bar kerana gaya bar tidak kelihatan dimampatkan apabila kita skala secara mendatar. Jika kita melakukan ini, kita boleh menghidupkan lebarnya. Ini bukan masalah yang besar, terutamanya kerana ia tidak akan menyesuaikan semula susun atur apa -apa lagi.

Sekarang kita memohon kepada bar:

 .Round-Time-Bar Div {
  / * ... */
  Animasi: Calc Roundtime (Var (-Durasi) * 1s) Langkah-langkah (var (-Durasi)) ke hadapan;
  Transform-Origin: Pusat Kiri;
}

Lihat bagaimana kita menggunakan pembolehubah --duration untuk menetapkan tempoh animasi? Ini mencapai sebahagian besar kerja. Saya juga menggunakannya untuk menetapkan bilangan steps() supaya pengurangan "grid oleh grid". "Bid-by-frame" mungkin kesan UI visual yang anda suka (saya suka), tetapi ia juga menyesuaikan diri dengan idea bahawa JavaScript boleh membuat semula bar ini pada bila-bila masa, dan bingkai bingkai membuatnya tidak dapat diperhatikan. Saya menggunakan integer sebagai nilai tempoh supaya kedua -duanya boleh menggunakannya seperti ini.

Walau bagaimanapun, jika anda mahukan animasi yang lancar, kita boleh melakukan ini, sebagai contoh:

<div ...="" data-style="smooth"></div>

Maka jangan gunakan steps :

 .Round-time-bar [data-style = "smooth"] div {
  Animasi: Calc Roundtime (Var (-Durasi) * 1s) Linear Forward;
}

Perhatikan bahawa kami juga menggunakan animasi linear, yang nampaknya masuk akal untuk pemasa. Masa, suka, tidak akan senang. Atau adakah ia? Bagaimanapun, ini adalah pilihan anda. Jika anda mahu pemasa yang kelihatan seperti pecutan atau penurunan pada titik tertentu, pergi untuk itu.

Kita boleh menggunakan API berasaskan data-attribute yang sama untuk melaksanakan perubahan warna:

 .Round-time-bar [data-color = "blue"] div {
  Latar Belakang: Linear-Gradient (ke bawah, #64B5F6, #1565C0);
}

Varian terakhir adalah untuk menetapkan lebar setiap "kedua". Dengan cara ini, pemasa 10 saat akan kelihatan lebih lama daripada pemasa 5 saat:

 .Round-time-bar [data-style = "fixed"] div {
  lebar: calc (var (-durasi) * 5%);
}

Berikut adalah demonstrasi:

Perhatikan petua untuk memulakan semula animasi CSS.

Oh, dengan cara ini, saya tahu ada satu<meter></meter> Unsur, ia mungkin lebih semantik, tetapi UI sendiri tidak boleh bernyawa seperti yang saya mahu di sini - sekurang -kurangnya tidak melawannya. Tetapi saya tidak tahu sama ada ia lebih mudah diakses? Adakah ia mengisytiharkan nilai semasa dengan cara yang berguna? Sekiranya kita menggunakan JavaScript untuk dikemas kini dalam masa nyata<meter></meter> , adakah ia menjadi pemasa yang lebih mudah diakses? Jika ada yang tahu, saya boleh menghubungkan penyelesaian di sini.

Atas ialah kandungan terperinci Bar pemasa di CSS dengan sifat tersuai. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
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
Berita Platform Mingguan: Aplikasi Web di Kedai Galaxy, Cerita Tappable, CSS SubgridBerita Platform Mingguan: Aplikasi Web di Kedai Galaxy, Cerita Tappable, CSS SubgridApr 14, 2025 am 11:20 AM

Dalam roundup minggu ini: Firefox Gains Locksmith seperti kuasa, Samsung ' s Galaxy Store mula menyokong aplikasi web progresif, subgrid CSS adalah penghantaran di Firefox

Kekuatan (dan keseronokan) skop dengan sifat tersuai CSSKekuatan (dan keseronokan) skop dengan sifat tersuai CSSApr 14, 2025 am 11:11 AM

Anda mungkin sudah sekurang -kurangnya sedikit biasa dengan pembolehubah CSS. Jika tidak, inilah gambaran keseluruhan dua saat: mereka benar-benar dipanggil sifat tersuai, anda menetapkan

Kami adalah pengaturcaraKami adalah pengaturcaraApr 14, 2025 am 11:04 AM

Laman web bangunan adalah pengaturcaraan. Menulis HTML dan CSS adalah pengaturcaraan. Saya seorang pengaturcara, dan jika anda ' di sini, membaca css-tricks, kemungkinan anda '

Bagaimana anda mengeluarkan CSS yang tidak digunakan dari laman web?Bagaimana anda mengeluarkan CSS yang tidak digunakan dari laman web?Apr 14, 2025 am 10:59 AM

Di sini ' s Apa yang saya suka untuk mengetahui pendahuluan: Ini adalah masalah yang sukar. Sekiranya anda mendarat di sini kerana anda berharap dapat menunjuk pada alat yang boleh anda jalankan

Pengenalan kepada API Web Picture-in-PicturePengenalan kepada API Web Picture-in-PictureApr 14, 2025 am 10:57 AM

Picture-in-Picture membuat penampilan pertamanya di web di pelayar safari dengan pembebasan macos Sierra pada tahun 2016. Ia memungkinkan pengguna untuk muncul

Cara untuk mengatur dan menyediakan imej untuk kesan kabur menggunakan GatsbyCara untuk mengatur dan menyediakan imej untuk kesan kabur menggunakan GatsbyApr 14, 2025 am 10:56 AM

Gatsby melakukan pemprosesan kerja yang hebat dan mengendalikan imej. Contohnya, ia membantu anda menjimatkan masa dengan pengoptimuman imej kerana anda tidak perlu secara manual

Oh hei, peratusan padding didasarkan pada elemen induk ' s lebarOh hei, peratusan padding didasarkan pada elemen induk ' s lebarApr 14, 2025 am 10:55 AM

Saya belajar sesuatu mengenai padding berasaskan peratusan hari ini bahawa saya benar-benar salah di kepala saya! Saya selalu menganggap bahawa padding peratusan berdasarkan

See all articles

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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
4 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
WWE 2K25: Cara Membuka Segala -galanya Di Myrise
1 bulan yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.