CSS 实现网站变灰的方案

实现网站变灰通常是为了响应某种特定事件或纪念日,例如悼念等。这可以通过在网站的最外层添加一个全局的 CSS 样式来实现。

以下是几种不同的实现方法:

方法 1:使用 filter 属性

CSS 的 filter 属性提供了一种简单的方法来实现这一点。

css 复制代码
html {
  filter: grayscale(100%);
}

或者,如果你想要对整个页面应用这个效果,你也可以使用:

css 复制代码
body * {
  filter: grayscale(100%) !important;
}

注意:使用 !important 是为了确保该样式能覆盖其他可能影响颜色的样式。

方法 2:使用 SVG 滤镜

另一种方法是使用 SVG 滤镜。这通常是更复杂的做法,但它提供了更多的控制能力。

首先,创建一个 SVG 文件(或直接在 HTML 文件中嵌入 SVG):

html 复制代码
<svg xmlns="http://www.w3.org/2000/svg">
  <filter id="grayscale">
    <feColorMatrix type="matrix" values="0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0" />
  </filter>
</svg>

然后,在 CSS 中引用这个滤镜:

css 复制代码
html {
  filter: url(#grayscale);
}

或者

css 复制代码
body * {
  filter: url(#grayscale) !important;
}

方法 3:使用 JavaScript 动态切换

如果你想要能够动态地开启或关闭这个效果,你可以使用 JavaScript 来添加或删除一个样式类:

javascript 复制代码
function toggleGrayscale() {
  const element = document.documentElement;
  element.classList.toggle('grayscale');
}

然后在 CSS 中定义这个样式类:

css 复制代码
.grayscale {
  filter: grayscale(100%);
}

这样,你就可以通过调用 toggleGrayscale() 函数来动态地开启或关闭灰度效果。

以上就是几种实现网站变灰的方法,你可以根据自己的需求来选择最适合你的方案。

相关推荐
counterxing2 小时前
我整理了一个免费开发资源目录,还做成了 CLI 和 MCP
前端·agent·ai编程
子兮曰9 小时前
Bun v1.3.14 深度解析:Image API、HTTP/3、全局虚拟存储与五十项变革
前端·后端·bun
kyriewen10 小时前
今天,百年巨头一次砍了9200人,而一个离职科学家的实话让全网睡不着觉
前端·openai·ai编程
问心无愧051310 小时前
ctf show web 入门42
android·前端·android studio
kyriewen11 小时前
老板逼我上AI,我偷偷在浏览器里跑LLaMA,省下20万API费
前端·react.js·llm
Beginner x_u11 小时前
前端八股整理(手写 02)|数组转树、数组扁平化、随机打乱一个数组
前端·数组·数组转树·数组扁平化
KaMeidebaby11 小时前
卡梅德生物技术快报|禽类成纤维细胞 FISH 实验:鸟类性别染色体基因定位技术实现与数据验证
前端·数据库·其他·百度·新浪微博
天若有情67311 小时前
前端高阶性能优化:跳出传统懒加载与预加载,基于用户行为做轻量预判加载
前端·性能优化
小小小小宇11 小时前
前端转后端:SQL 是什么
前端
张元清12 小时前
React Observer Hooks:7 种监听 DOM 而不写样板代码的方式
前端·javascript·面试