CSS:怎么把网站都变成灰色

当大家看到全站的内容都变成了灰色,包括按钮、图片等等。这时候我们可能会好奇这是怎么做到的呢?

有人会以为所有的内容都统一换了一个 CSS 样式,图片也全换成灰色的了,按钮等样式也统一换成了灰色样式。但你想想这个成本也太高了,而且万一某个控件忘记加灰色样式了岂不是太突兀了。

其实,解决方案很简单,只需要几行代码就能搞定了。通过参考资料,我总结出以下几个方法可以帮助我们达到目的:

使这个网页的颜色变成灰色的最简单的方法,就是在当前页面的css里面。添加下面的代码,并且让他在任意的浏览器里面正确的执行:

方法一

<style type="text/css">
html {
	filter:grayscale(100%);  
	-webkit-filter:grayscale(100%);  
	-moz-filter:grayscale(100%);  
	-ms-filter:grayscale(100%);  
	-o-filter:grayscale(100%); 
	filter:progid:DXImageTransform.Microsoft.BasicImage(grayscale=1); 
	 -webkit-filter:grayscale(1)
}
</style>

filter是滤镜的意思,filter:gray的意思就是说给页面加上一个灰度的滤镜,所以html里面的所有内容都会变成黑白的了。不过这个滤镜对于chrome和safari浏览器是无效的,所以下面会有一行-webkit-filter: grayscale(100%);这个样式是专属于使用webkit内核的浏览器的,意思和FILTER: gray;差不多,只是写法不同罢了。

方法二

下面这段代码可以把网页变为黑白,将代码加到 CSS 最顶端就可以实现素装,如果网站没有使用 CSS,可以在网页/模板的 HTML 代码和 之间插入:

<style> 
html {
	 filter: progid:DXImageTransform.Microsoft.BasicImage(grayscale=1);
	-webkit-filter: grayscale(100%);
}
</style>

有一些网站可能使用这个 css 不能生效,是因为网站没有使用最新的网页标准协议,请将网页最头部的替换为以下代码:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" 
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">

还有一些网站 FLASH 动画的颜色不能被 CSS 滤镜控制,可以在 FLASH 代码的和之间插入:

<param value="false" name="menu"/>
<param value="opaque" name="wmode"/>

最后

给出一段规范的代码,把这段代码加入到网站页面的css里面即可实现页面变成灰色的效果:

html {   
	 -webkit-filter: grayscale(100%);
	 -moz-filter: grayscale(100%);   
	 -ms-filter: grayscale(100%);   
	 -o-filter: grayscale(100%);   
	 filter: grayscale(100%);   
	 filter: url("data:image/svg+xml;utf8,<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>#grayscale");    
	 filter: progid:DXImageTransform.Microsoft.BasicImage(grayscale=1)
 }
相关推荐
余生H26 分钟前
Angular v19 (二):响应式当红实现signal的详细介绍:它擅长做什么、不能做什么?以及与vue、svelte、react等框架的响应式实现对比
前端·vue.js·react.js·angular.js
聚宝盆_36 分钟前
【记录:前端提高用户体验】
前端·css
GISer_Jing1 小时前
Vue前端进阶面试题(六)
前端·javascript·vue.js
之诚2 小时前
使用Gradle编译前端的项目
前端·vue·gradle
FenceRain2 小时前
uniapp 扩展picker-view实现条件查询
前端·javascript·uni-app
喵喵酱仔__2 小时前
uniapp echarts tooltip formation 不识别html
前端·javascript·echarts
new出一个对象2 小时前
uniapp在App端定义全局弹窗,当打开关闭弹窗会触发onShow、onHide生命周期怎么解决?
前端·uni-app
EterNity_TiMe_2 小时前
【论文复现】上下位关系自动检测方法
前端·javascript·网络·人工智能·前端框架·easyui
天农学子2 小时前
Easyui 实现订单拆分开票功能
前端·javascript·easyui
Swift社区3 小时前
工具与技术在 Debug 中的应用
前端·typescript·debug