Bagaimana cara menambahkan warna gelap/terang atau multi-tema hanya dengan menggunakan CSS?
Tema Gelap/Terang atau implementasi fitur multi-tema seperti yang ditawarkan Twitter adalah salah satu fitur dasar dari setiap aplikasi web/seluler kecil/menengah/besar saat ini karena sebagian besar orang yang menggunakan aplikasi tersebut kemungkinan besar akan memilikinya preferensi warna dan Anda harus mengembangkan aplikasi Anda dengan cara yang dapat memenuhi kebutuhan mereka untuk menciptakan pengalaman pengguna yang lebih baik di seluruh aplikasi Anda tidak peduli di web atau perangkat seluler.
TLDR;
Tanpa basa-basi lagi, mari kita mulai dengan mengimplementasikan fitur ini di dalam aplikasi React, tetapi perhatikan bahwa fitur ini akan menggunakan fitur khusus CSS dan manipulasi DOM sehingga Anda dapat menggunakannya di semua framework/library atau aplikasi HTML/CSS murni.
1- Tentukan file CSS/SCSS/Styled-Component/CSS-In-JS global yang mengontrol dan mewakili arahan gaya global atau sistem desain Anda.
Di atas, seperti yang Anda lihat, saya telah membuat file gaya global menggunakan akhiran SCSS dan menentukan aturan root di dalamnya yang menentukan warna dan font saya, root pada dasarnya ada untuk membantu Anda memusatkan variabel Anda seperti warna, ukuran, font , margin, padding dan lain-lain.
2- Buat komponen Tema untuk menangani fungsi tema toggle Anda seperti di bawah ini:
import { useState } from "react";
const Theme = () => {
const [theme, setTheme] = useState("light");
const toggleTheme = () => {
setTheme((prev) => {
const newThemeValue = prev === "light" ? "dark" : "light";
// Add theme attribute with respective them value of the state
document.body.setAttribute("theme", newThemeValue);
return newThemeValue;
});
};
return (
<div>
<button onClick={toggleTheme}>
{theme === "light" ? "dark" : "light"}
</button>
</div>
);
};
export default Theme;
Bagian terpenting di sini adalah mengatur atribut ke badan dokumen HTML Anda misalnya di sini saya menambahkan atribut tema dan menetapkan nilainya ke nilai tema saya agar dapat menargetkannya di file CSS saya.
Catatan: ingat bahwa ini tidak merender ulang seluruh aplikasi Anda di React tetapi yang Anda lakukan adalah manipulasi DOM secara langsung di pengendali kejadian React jadi jika Anda ingin mengakses nilai tema di seluruh aplikasi Anda, gunakan itu di komponen Anda, Anda dapat menggunakan konteks global dan bungkus aplikasi Anda di dalamnya untuk tema Anda, tetapi karena itu menghancurkan satu-satunya tujuan CSS dari pekerjaan kami, kami tidak akan melakukannya di sini.
3- Tambahkan variabel tema gelap dan tema target sesuai dengan atribut gelap tubuh HTML Anda.
Sekarang tentukan pemilih CSS berdasarkan atribut tubuh HTML Anda, dalam hal ini karena saya menyebutnya "mereka", saya akan memilih [theme="dark"] di sini dan menentukan warna baru untuk variabel saya.
Peasy mudah bukan?
4- Tema multi dan bagaimana nilai variabel diubah?
Dengan pendekatan di atas, Anda dapat menggunakan beberapa nilai tema atau bahkan membuatnya dinamis sehingga Anda tidak hanya dapat memiliki mode gelap dan terang, Anda juga dapat membuat jenis lain seperti biru atau merah atau lainnya.
Pada dasarnya, pendekatan ini berfungsi seperti ini, Anda menentukan variabel dan warna di pemilih root, lalu Anda menargetkan nilai tema tubuh HTML dan mengubah warna variabel yang sama dengan yang Anda tentukan, CSS secara otomatis akan mengganti warna baru di dalam aplikasi Anda .
Bonus: Jika Anda ingin mempertahankan nilai tema di aplikasi Anda, Anda dapat menyimpannya di data profil pengguna di database Anda, tetapi pendekatan termudah di sini adalah menyimpan nilai di penyimpanan lokal.
Saya menyetel item tema di penyimpanan lokal saya dan setiap kali aplikasi saya melakukan hard refresh atau jika saya menutup sesi (tab) dan kembali lagi, saya membaca data tema dari penyimpanan lokal.
import { useEffect, useState } from "react";
const Theme = () => {
const [theme, setTheme] = useState("light");
useEffect(() => {
const currentTheme = localStorage.getItem("theme");
if (currentTheme) {
setTheme(currentTheme);
document.body.setAttribute("theme", currentTheme);
}
}, []);
const toggleTheme = () => {
setTheme((prev) => {
const newThemeValue = prev === "light" ? "dark" : "light";
// Add theme attribute with respective them value of the state
document.body.setAttribute("theme", newThemeValue);
// Persist the current theme value in localStorage
localStorage.setItem("theme", newThemeValue);
return newThemeValue;
});
};
return (
<div>
<button onClick={toggleTheme}>
{theme === "light" ? "dark" : "light"}
</button>
</div>
);
};
export default Theme;