如何給Web頁面增加夜間模式功能? 其實所謂的夜間模式就是在頁面上增加一個透明的遮罩層,但是遮罩層會擋住頁面元素, 解決方法是 添加DIV,給DIV的outline屬性一個很大的outline-width值,用outline的邊框作為遮罩,這樣既能正常點擊頁面元素,又能達到夜間模式的效果
HTML+CSS: 代碼如下: <div class="cover"></div> 代碼如下: <style> .cover{ position:fixed; top: 0px; left: 0px; outline:5000px solid rgba(0, 0, 0, 0.3); z-index: 99999; } </style> 接著用JavaScript寫個夜間模式plus: 代碼如下: <script> var brightness; //顯示遮罩 function cover(brightness) { if (typeof(div) == 'undefined') { div = document.createElement('div'); div.setAttribute('style', 'position:fixed;top:0;left:0;outline:5000px solid;z-index:99999;'); document.body.appendChild(div); } else { div.style.display = ''; } div.style.outlineColor = 'rgba(0,0,0,' + brightness + ')'; } //事件監聽 window.addEventListener('keydown', function(e) { if (e.altKey && e.keyCode == 90) { //Alt+Z:打開夜間模式 cover(brightness = 0.3); } if (e.altKey && e.keyCode == 88) { //Alt+X:關閉 cover(brightness = 0); } if (e.altKey && e.keyCode == 38) { //Alt+↑:增加亮度 if (brightness - 0.05 > 0.05) cover(brightness -= 0.05); } if (e.altKey && e.keyCode == 40) { //Alt+↓:降低亮度 if (brightness + 0.05 < 0.95) cover(brightness += 0.05); } }, false); </script> 還可以寫成GreaseMonkey腳本,作為浏覽器擴展給任意頁面增加夜間模式