Rumah hujung hadapan web tutorial css Anda tidak memerlukan pra-pemproses CSS

Anda tidak memerlukan pra-pemproses CSS

Nov 01, 2024 am 08:56 AM

You don

CSS asli telah berkembang pesat dalam beberapa bulan/tahun kebelakangan ini. Dalam siaran ini, saya akan membincangkan sebab utama orang ramai menggunakan pra-pemproses css seperti SASS, LESS dan Stylus, dan menunjukkan kepada anda cara anda boleh mencapai perkara yang sama ini dengan CSS asli.

Mengasingkan fail

Memisahkan fail ialah salah satu sebab utama orang ramai mendapatkan pra-pemproses. Untuk beberapa lama sekarang walaupun anda telah dapat mengimport fail lain ke dalam fail CSS. Ia kelihatan seperti ini.

@import url("./utils.css");
Salin selepas log masuk
Salin selepas log masuk

Anda boleh menggunakan laluan relatif atau mutlak, sama seperti anda menggunakan href pada tag anchor atau mana-mana sumber lain.

Perbezaan utama antara pra-pemproses ini ialah semasa pra-pemproses akan bergabung kemudian pada penyusunan, CSS akan membuat permintaan http pada masa jalan.

Peraturan bersarang

Ok ini sebab utama guna pre-processor. Sekurang-kurangnya itu sebab utama saya menggunakan satu pada masa lalu.

Tetapi CSS kini menyokong sarang dan ia berfungsi kebanyakannya seperti biasa anda menggunakan prapemproses.

header {
  h1 {
    font-weight: bold;
  }

  h2 {
    font-weight: normal;
  }
}

Salin selepas log masuk
Salin selepas log masuk

Agak hebat, satu kelebihan besar untuk menulis CSS seperti yang kami ada selama beberapa dekad.

header h1 {
  font-weight: bold;
}

header h2 {
  font-weight: normal;
}
Salin selepas log masuk
Salin selepas log masuk

Pemilih sudo

Pemilih sudo berfungsi dengan cara yang sama dalam css asli yang mungkin anda biasa gunakan daripada pra-pemproses juga.

button {
  color: blue;

  &:hover {
    color: purple;
  }
}
Salin selepas log masuk

Anda boleh membaca lebih lanjut tentang bersarang di MDN.

Pembolehubah

Sebab lama untuk prapemproses adalah pembolehubah. Anda boleh mempunyai semua warna anda, jarak dll dalam satu fail dan mengemas kini secara global di mana-mana sahaja.

Nah, anda boleh melakukannya dalam CSS asli sekarang, untuk beberapa lama. Malah dalam beberapa cara ia lebih baik daripada pra-pemproses.

Pembolehubah global

Pembolehubah global disertakan dalam peraturan :root. Ini boleh dirujuk di mana-mana sahaja.

:root {
  --bg-color: #333;
}
Salin selepas log masuk

Untuk menggunakan pembolehubah, ia mesti dirujuk dengan teg var

button {
  background-color: var(--bg-color);
}
Salin selepas log masuk

Pembolehubah berskop

Anda juga boleh menskop pembolehubah pada pemilih, contohnya...

header {
  --bg-color: #999;
}
Salin selepas log masuk

Jadi dalam kes ini, merujuk var(--bg-color); dalam pemilih pengepala akan menghasilkan #999;

Menetapkan semula nilai pada masa jalan

Jadi kelebihan utama dengan pembolehubah css berbanding prapemproses, ialah pembolehubah itu boleh diatasi semasa masa jalan, di mana prapemproses sebaik sahaja ia disusun, ia kekal.

Jadi sebagai contoh jika anda mempunyai tapak web yang anda mahu menyokong mod terang dan gelap. Ini boleh dicapai dengan mudah menggunakan css vars.

:root {
  --bg-color: white;
}

body {
  background-color: var(--bg-color);
}

@media (prefers-color-scheme: dark) {
  :root {
    --bg-color: black;
  }
}
Salin selepas log masuk

Untuk mencapai sesuatu seperti ini dengan prapemproses, anda perlu menogol kelas pada badan menggunakan Javascript dan mengatasi semua peraturan dengan kelas .dark atau sejenisnya.

Pengiraan

Kebanyakan pra-pemproses seperti LESS, Stylus atau SASS membolehkan anda membuat pengiraan tentang sesuatu. Suka jika anda ingin membahagikan pembolehubah kepada separuh ect.

Anda boleh melakukannya dalam css asli menggunakan fungsi calc.

@import url("./utils.css");
Salin selepas log masuk
Salin selepas log masuk

betapa hebatnya?

Mengubah warna

Jadi satu lagi ciri popular (sekurang-kurangnya bagi saya) ialah untuk mencerahkan dan menggelapkan warna dalam pra-pemproses css. Anda boleh melakukan ini dalam css asli sekarang juga menggunakan campuran warna.

header {
  h1 {
    font-weight: bold;
  }

  h2 {
    font-weight: normal;
  }
}

Salin selepas log masuk
Salin selepas log masuk

Perkara di atas adalah bersamaan dengan perkara yang biasa anda lakukan dengan pencerah(merah, 50%) dalam prapemproses.

Untuk menggelapkan hanya campurkan dengan hitam dan bukannya putih

header h1 {
  font-weight: bold;
}

header h2 {
  font-weight: normal;
}
Salin selepas log masuk
Salin selepas log masuk

Saya harap kali seterusnya anda memilih alatan yang hendak digunakan pada projek, anda akan mencuba css asli. Ia telah berjalan jauh.

Atas ialah kandungan terperinci Anda tidak memerlukan pra-pemproses CSS. 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

Tag artikel 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)

Menambah bayang -bayang kotak ke blok dan elemen WordPress Menambah bayang -bayang kotak ke blok dan elemen WordPress Mar 09, 2025 pm 12:53 PM

Menambah bayang -bayang kotak ke blok dan elemen WordPress

Buat borang hubungan JavaScript dengan rangka kerja pintar Buat borang hubungan JavaScript dengan rangka kerja pintar Mar 07, 2025 am 11:33 AM

Buat borang hubungan JavaScript dengan rangka kerja pintar

Buat editor teks sebaris dengan atribut yang boleh dipertikaikan Buat editor teks sebaris dengan atribut yang boleh dipertikaikan Mar 02, 2025 am 09:03 AM

Buat editor teks sebaris dengan atribut yang boleh dipertikaikan

Bekerja dengan Caching Graphql Bekerja dengan Caching Graphql Mar 19, 2025 am 09:36 AM

Bekerja dengan Caching Graphql

Menjadikan Peralihan Svelte Khas pertama anda Menjadikan Peralihan Svelte Khas pertama anda Mar 15, 2025 am 11:08 AM

Menjadikan Peralihan Svelte Khas pertama anda

Pembaca Skrin Demystifying: Borang & Amalan Terbaik Diakses Pembaca Skrin Demystifying: Borang & Amalan Terbaik Diakses Mar 08, 2025 am 09:45 AM

Pembaca Skrin Demystifying: Borang & Amalan Terbaik Diakses

Membandingkan 5 Pembina Borang PHP Terbaik (dan 3 skrip percuma) Membandingkan 5 Pembina Borang PHP Terbaik (dan 3 skrip percuma) Mar 04, 2025 am 10:22 AM

Membandingkan 5 Pembina Borang PHP Terbaik (dan 3 skrip percuma)

Muat naik fail dengan multer di node.js dan ekspres Muat naik fail dengan multer di node.js dan ekspres Mar 02, 2025 am 09:15 AM

Muat naik fail dengan multer di node.js dan ekspres

See all articles