w

그누보드 다크모드 만들기 PHP & Javascript

<?php $themeClass = ''; if (!empty($_COOKIE['theme'])) { if ($_COOKIE['theme'] == 'dark') { $themeClass = 'dark-theme'; } else if ($_COOKIE['theme'] == 'light') { $themeClass = 'light-theme'; } } ?>

 

위 소스코드를 head.php 에 넣어주시고

 <body class="<?php echo $themeClass; ?>">

 

테마의 head.php 나 head.sub.php 에 body 태그를 찾아서 class 에 넣어주세요.

 

원하는 다크모드 on off 하는 버튼 넣어주세요.

<script> const btn = document.querySelector(".btn-toggle"); const prefersDarkScheme = window.matchMedia("(prefers-color-scheme: dark)"); btn.addEventListener("click", function() { if (prefersDarkScheme.matches) { document.body.classList.toggle("light-mode"); var theme = document.body.classList.contains("light-mode") ? "light" : "dark"; } else { document.body.classList.toggle("dark-mode"); var theme = document.body.classList.contains("dark-mode") ? "dark" : "light"; } document.cookie = "theme=" + theme; }); </script> 

 

css 에서 light 나 dark 속성을 이용해서 만드시면 됩니다..

 

ex)

.light button { .... }

.light .calendar { ... }

|

댓글 4개

수고가 많으셨습니다.
좋은정보 감사 드려요.
좋은 팁이네요..
안되는것 같아요 ㅠㅠ
@문선생 css는 직접 만드셔야죠
댓글을 작성하시려면 로그인이 필요합니다.

그누보드5 팁자료실

+
제목 글쓴이 날짜 조회
4년 전 조회 5,708
4년 전 조회 2,929
4년 전 조회 3,602
4년 전 조회 3,025
4년 전 조회 3,791
4년 전 조회 3,475
4년 전 조회 2,501
4년 전 조회 4,923
4년 전 조회 4,033
4년 전 조회 3,669
4년 전 조회 3,642
4년 전 조회 4,937
4년 전 조회 3,541
4년 전 조회 3,409
4년 전 조회 4,775
4년 전 조회 6,138
4년 전 조회 5,734
4년 전 조회 4,839
4년 전 조회 7,200
4년 전 조회 2,817
4년 전 조회 3,451
4년 전 조회 4,749
4년 전 조회 3,886
4년 전 조회 3,556
4년 전 조회 5,565
4년 전 조회 2,745
4년 전 조회 8,050
4년 전 조회 5,415
4년 전 조회 4,090
4년 전 조회 5,533