BAT 用一行代码实现了网页黑白显示

今天全网页面置灰,「Vue虚拟实验室」也不例外。

在前端最少只用“一行”代码即可搞定。那么是如何实现的呢?

我们先看看以下公司是如何实现的呢?

1、百度

2、今日头条

3、阿里云

4、腾讯

从上面的实现方式可以看到,关键技术是利用了 CSS 的 filter 技术,也就是 CSS 的滤镜功能。

我们看看 MDN 关于 filter 的描述:

The filter CSS property applies graphical effects like blur or color shift to an element. Filters are commonly used to adjust the rendering of images, backgrounds, and borders.

Included in the CSS standard are several functions that achieve predefined effects. You can also reference an SVG filter with a URL to an SVG filter element.

大意是使用 filter 可以给 HTML 元素添加一些效果,比如模糊、颜色偏移,通常用于调整图像,背景和边框的渲染。

CSS 标准里包含了一些预定义效果的函数,你也可以通过一个URL 使用 SVG 滤镜元素(SVG filter element)。

我们分析下下面这段代码:

grayscale: 函数是 CSS 预定义的函数,主要作用是将图像转换为灰度图像,通过具体的值定义转换的比例。若值为 100% 则完全转为灰度图像,值为 0% 图像无变化。

下面这些前缀都是为了适配不同的浏览器,不然会有兼容性问题:

-webkit-filter: 谷歌, Safari, 新版Opera浏览器, 以及几乎所有iOS系统中的浏览器(包括iOS 系统中的火狐浏览器); 简单的说,所有基于WebKit 内核的浏览器;

-moz-filter: 火狐浏览器;

-ms-filter: IE浏览器 和 Edge浏览器;

-o-filter: 旧版Opera浏览器;

filter: progid:DXImageTransform.Microsoft.BasicImage(grayscale=1): 

这个是个给 IE 浏览器添加滤镜的,IE 浏览器对 filter 支持的不是很好。

总之,上面写了一坨代码,都是为了更好支持不同的浏览器。

参考:

https://developer.mozilla.org/zh-CN/docs/Glossary/Vendor_Prefix

https://developer.mozilla.org/zh-CN/docs/Web/CSS/filter

https://blog.csdn.net/jiudihanbing/article/details/8372947


推荐阅读:

各种博客的代码高亮是如何实现的

太强了,从 0 到 1 搭建 vue-cli

让 Class 与 Style 动起来

众人拾柴火焰高 · Vue虚拟实验室

要编写一个能够在打开网页界面时即可运行bat文件的代码,你可以使用网页技术来触发一个自动下载并执行bat文件的操作。通常,网页本身不能直接执行文件系统操作,但是可以通过一些方式诱导用户下载并执行bat文件。这里提供一种基本的思路: 1. 将bat文件托管在一个可以公开访问的服务器上。 2. 在网页中嵌入一个指向该bat文件的链接。 3. 使用JavaScript来自动触发下载或执行操作。 以下是一个简化的示例: HTML部分(index.html): ```html <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>Run Bat File</title> </head> <body> <!-- 用户点击后会自动下载或尝试执行bat文件 --> <a href="https://yourserver.com/path/to/yourfile.bat" id="runBatFile">运行批处理文件</a> <script> // 当页面加载完成后,尝试自动执行下载 window.onload = function() { var link = document.getElementById('runBatFile'); link.click(); }; </script> </body> </html> ``` 请注意,出于安全考虑,现代浏览器通常会阻止自动执行未明确触发的下载。上面的代码可能在不同的浏览器上有不同的表现,且可能会被浏览器的安全策略所阻止。用户可能需要手动点击链接才能下载bat文件。 这个方法是不推荐的,因为它可能会被恶意利用,触发用户执行未授权的脚本。通常情况下,开发者应该避免在网页上运行bat文件,以保护用户的安全。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值