使用javascript为网页增加夜间模式

如何给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脚本,作为浏览器扩展给任意页面增加夜间模式

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
实现夜间模式可以通过以下两种方式: 1. 使用CSS 可以使用CSS中的 `:root` 和 `:not` 选择器以及 `var()` 函数来实现夜间模式。首先,定义两个不同的CSS变量,分别表示白天和夜间的颜色,如下所示: ```css :root { --bg-color: #fff; /* 白天背景颜色 */ --text-color: #333; /* 白天文字颜色 */ } :not(.night-mode) { background-color: var(--bg-color); color: var(--text-color); } .night-mode { --bg-color: #222; /* 夜间背景颜色 */ --text-color: #ccc; /* 夜间文字颜色 */ } ``` 然后,在HTML中添加一个按钮,用于切换夜间模式: ```html <button onclick="toggleNightMode()">夜间模式</button> ``` 最后,在JavaScript中实现 `toggleNightMode()` 函数,用于切换夜间模式: ```javascript function toggleNightMode() { document.body.classList.toggle('night-mode'); } ``` 这样,当用户点击按钮时,`night-mode` 类会被添加到 `body` 元素上,从而切换到夜间模式。 2. 使用JavaScript 可以使用JavaScript来动态修改CSS样式,实现夜间模式。首先,定义白天和夜间的颜色: ```css body { background-color: #fff; /* 白天背景颜色 */ color: #333; /* 白天文字颜色 */ } .night-mode body { background-color: #222; /* 夜间背景颜色 */ color: #ccc; /* 夜间文字颜色 */ } ``` 然后,在HTML中添加一个按钮,用于切换夜间模式: ```html <button onclick="toggleNightMode()">夜间模式</button> ``` 最后,在JavaScript中实现 `toggleNightMode()` 函数,用于切换夜间模式: ```javascript function toggleNightMode() { document.body.classList.toggle('night-mode'); } ``` 这样,当用户点击按钮时,`night-mode` 类会被添加到 `body` 元素上,从而切换到夜间模式
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值