實作
建立 AppThemeSwitch.svelte
檔。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36
| <script lang="ts"> import { onMount } from 'svelte'; import AppIcon from './AppIcon.svelte';
const THEME_LIGHT = 'light'; const THEME_DARK = 'dark'; const THEME_STORAGE_KEY = 'theme';
let theme: string;
$: isDarkTheme = theme === THEME_DARK;
onMount(() => { const prefersDarkScheme = window.matchMedia('(prefers-color-scheme: dark)');
setTheme(localStorage.getItem(THEME_STORAGE_KEY) || (prefersDarkScheme.matches ? THEME_DARK : THEME_LIGHT));
prefersDarkScheme.addEventListener('change', (event) => { setTheme(event.matches ? THEME_DARK : THEME_LIGHT); }); });
const setTheme = (v: string) => { theme = v; document.documentElement.setAttribute('data-bs-theme', theme); localStorage.setItem(THEME_STORAGE_KEY, theme); };
const toggleTheme = () => { setTheme(isDarkTheme ? THEME_LIGHT : THEME_DARK); }; </script>
<button type="button" class="btn btn-dark-variant px-2" on:click={toggleTheme}> <AppIcon icon={isDarkTheme ? 'light_mode' : 'dark_mode'} /> </button>
|
使用。