暗い場所で、ページを開くと、白いブログの背景色が目に刺さるなんてことがあります。グーグルマップなんかは、トンネルに入ると黒背景で表示されますね。背景色の切り替えは、javascriptでやるケースが多いのかもしれませんが、ちょっと工夫するとCSSでも簡単にできます。
input#dark:checked~.switch-presentation{ --bg:#333; --fg:#fff; }
この部分で色を変更していますが、
もう一つのポイントは、label要素の位置は、for="id"を使っているので、チェックボックスと同じ場所に置かなくても動作してくれる点です。
アイコンをクリックしてください
Lorem ipsum dolor sit amet, consectetur adipiscing elit
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum
html
<input type="checkbox" id="dark" name="dark"> <div class="switch-presentation"> <label for="dark"><span class="day">☀</span><span class="moon">🌙</span></label> <div class="content"> <h1>Lorem ipsum dolor sit amet, consectetur adipiscing elit</h1> <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum</p> </div> </div>
CSS
@raindrops:root{ --bg:#fff; --fg:#333; } label span{ font-size:2rem; } .content{ margin-top:4rem; } .switch-presentation{ position:relative; padding:0 1rem 1rem; } .moon{ visibility:hidden; position:absolute; } input#dark:checked~.switch-presentation{ --bg:#333; --fg:#fff; } input#dark:checked~.switch-presentation .moon{ visibility:visible; position:absolute; } input#dark:checked~.switch-presentation .day{ visibility:hidden; position:absolute; } .switch-presentation{ background:var(--bg); color:var(--fg); } input"{ position:absolute; visibility:hidden; }
See the Pen CSS Day and night by tenman (@tenman-the-reactor)
on CodePen.
Photo by Shaswot Bhandari on Unsplash