如何给Web、WordPress页面增加夜间模式功能? 最近给博客增加了这个功能,有人问我怎么做,现在就拿出了分享吧,
其实所谓的夜间模式就是在页面上增加一个透明的遮罩层,但是遮罩层会挡住页面元素, 解决方法是 添加DIV,给DIV的outline属性一个很大的outline-width值,用outline的边框作为遮罩,这样既能正常点击页面元素,又能达到夜间模式的效果。实际效果你可以在本站试试
本文需回复可见
HTML+div代码如下:
<div class="cover"></div>
css代码如下:
/* ------------------------------------------------------------------------- * * 夜间模式 * ------------------------------------------------------------------------- */ .cover{ position:fixed; top: 0px; left: 0px; outline:5000px solid rgba(0, 0, 0, 0.0); z-index: 99999; }
接着用JavaScript写个夜间模式:
//显示遮罩 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.ctrlKey && e.keyCode == 90) { //Alt+Z:打开夜间模式 cover(brightness = 0.3); } if (e.ctrlKey && e.keyCode == 88) { //ctrl+X:关闭 cover(brightness = 0); } if (e.ctrlKey && e.keyCode == 39) { //Alt+→:增加亮度 if (brightness - 0.05 > 0.05) cover(brightness -= 0.05); } if (e.ctrlKey && e.keyCode == 37) { //Alt+←:降低亮度 if (brightness + 0.05 < 0.95) cover(brightness += 0.05); } }, false);
如果Alt键和系统发射冲突建议把altKey改成ctrlKey,意思是按Ctrl+。。。键控制啦
代码使用方法:
对于小白,这个是必须的,我建议把css代码放在wp主题的style.css文件里,如果你想让功能在全站实现;就把js和div放在底部,只是文章就加在文章页面,,,是不是有点废话了。
还可以写成GreaseMonkey脚本,作为浏览器扩展给任意页面增加夜间模式
赞赏历史上的文章
- 2017: Linux shell脚本实现检测mysql状态,挂掉立即自动重启( 0)
- 2017: linux定时任务crontab的基本配置格式( 0)
- 2016: 呵呵!腾讯cdn被阿里拦截( 0)
除特别注明外,本站所有文章均为LJY IT BLOG原创,转载请注明出处来自https://www.ljy2345.com/2015/08/%e4%bd%bf%e7%94%a8javascript%e4%b8%ba%e7%bd%91%e9%a1%b5%e5%a2%9e%e5%8a%a0%e5%a4%9c%e9%97%b4%e6%a8%a1%e5%bc%8f/
Comments | 5 comments
测试七牛评论
@Gyue:mrgreen: OK好滴
这个确实挺人性化哟
看下
:?: