前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >网页夜间效果

网页夜间效果

作者头像
Cell
发布2022-02-25 13:17:03
7040
发布2022-02-25 13:17:03
举报
文章被收录于专栏:Cell的前端专栏

这几天看到别人的博客有开关灯效果,就想给自己的博客也加一个,其实以前就在想了。经过谷歌百度后这样实现了。css+js

如何给 Web 页面增加夜间模式功能?其实所谓的夜间模式就是在页面上增加一个透明的遮罩层,但是遮罩层会挡住页面元素, 解决方法是 添加 DIV,给 DIV 的 outline 属性一个很大的 outline-width 值,用 outline 的边框作为遮罩,这样既能正常点击页面元素,又能达到夜间模式的效果。

css 部分

1 2 3 4 5 6 7 8 9

<style> .cover{ position:fixed; top: 0px; left: 0px; outline:5000px solid rgba(0, 0, 0, 0);//初始亮度 z-index: 99999; } </style>

js 部分

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29

<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) { cover(brightness = 0.3); } if (e.altKey && e.keyCode == 88) { cover(brightness = 0); } if (e.altKey && e.keyCode == 38) { if (brightness - 0.05 > 0.05) cover(brightness -= 0.05); } if (e.altKey && e.keyCode == 40) { if (brightness + 0.05 < 0.95) cover(brightness += 0.05); } }, false); </script>

html 部分

1

<div class="cover"></div>

使用

  1. Alt+Z: 打开夜间模式
  2. Alt+X: 关闭
  3. Alt+↑: 增加亮度
  4. Alt+↓: 降低亮度
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2018-09-27,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • css 部分
  • js 部分
  • html 部分
  • 使用
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档