”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何在不同浏览器中将背景图像转换为灰度?

如何在不同浏览器中将背景图像转换为灰度?

发布于2024-11-03
浏览:687

How to Convert Background Images to Greyscale Across Different Browsers?

如何使用 CSS 创建灰度背景图像

在这个充满活力和动态的网页设计时代,有时有必要融入一些微妙的简单性。实现此目的的一种方法是将背景图像转换为灰度,这可以为网站赋予经典或复古的美感。

跨浏览器 CSS3 过滤器

对背景进行灰度化的最直接方法图像是应用CSS3过滤器grayscale:

-webkit-filter: grayscale(100%);

但是,该技术仅适用于Chrome v.15和Safari v.6,因为浏览器兼容性限制。

跨浏览器 SVG 滤镜

要实现跨浏览器灰度效果,您可以利用 SVG 滤镜:

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");

此解决方案适用于大多数主要浏览器,包括 Firefox、Chrome 和 Edge。

jQuery 动画

如果您想使用 JavaScript 动态切换灰度效果,您可以使用 jQuery:

$(".nongrayscale").hover(function () {
  $(this).addClass("grayscale").fadeTo(400, 1);
});
$(".grayscale").hover(function () {
  $(this).removeClass("grayscale").fadeTo(400, 1);
});

此代码将添加灰度级,并在鼠标悬停时淡入图像。

IE10-11 兼容性

在 Internet Explorer 10-11 中,上述 SVG过滤技术不起作用。相反,您可以使用去饱和过滤器:

<filter xmlns="http://www.w3.org/2000/svg" id="desaturate">
  <feColorMatrix type="saturate" values="0" />
</filter>

此过滤器可以使用过滤器属性应用于图像。

通过利用这些方法,您可以轻松地在 CSS 中对背景图像进行灰度化,为您的网页添加永恒的触感设计同时保持跨浏览器兼容性。

最新教程 更多>
  • 如何捕获 JavaScript 中自定义异常的堆栈跟踪?
    如何捕获 JavaScript 中自定义异常的堆栈跟踪?
    获取一系列抛出的异常虽然 JavaScript 允许引发异常,但获取自定义异常的堆栈跟踪可能具有挑战性。本文探讨了专门针对用户定义的异常检索堆栈跟踪的各种方法。Error 对象的 stack 属性提供了一个简单的解决方案。通过创建一个新的 Error 对象并访问其 stack 属性,您可以捕获跟踪:...
    编程 发布于2024-11-08
  • 了解 React 中的关键属性 - 常见错误
    了解 React 中的关键属性 - 常见错误
    如果你喜欢我的文章,可以请我喝杯咖啡:) 在 React 中使用列表时,最关键的概念之一是 key 属性。键在 React 如何管理列表更新方面发挥着重要作用。 React 中的键是什么? 在 React 中,键是分配给列表中元素的唯一标识符。这些键帮助 React 确定哪些项目已更...
    编程 发布于2024-11-08
  • 掌握 React:构建强大 Web 应用程序的循序渐进之旅(简介)
    掌握 React:构建强大 Web 应用程序的循序渐进之旅(简介)
    React is a popular JavaScript library used to build user interfaces, especially for single-page websites or apps. Whether you're a complete beginner o...
    编程 发布于2024-11-08
  • JavaScript DOM 与 BOM!
    JavaScript DOM 与 BOM!
    DOM DOM 代表文档对象模型,代表网页。这允许程序操纵文档结构、样式和内容。 const listDiv = document.getElementById("list-div"); listDiv.classList.add('new-class'); listDiv.cla...
    编程 发布于2024-11-08
  • 绑定和模板:Peasy-UI 系列的一部分
    绑定和模板:Peasy-UI 系列的一部分
    Table of Contents Introduction Bindings and the Template Text Bindings Basic Binding Conditional Boolean Text B...
    编程 发布于2024-11-08
  • 实现接口
    实现接口
    定义接口后,一个或多个类可以实现它。 要实现接口,请在类定义中使用 Implements 子句。 该类必须实现接口所需的所有方法。 包含 Implements 子句的类的一般形式是: 类类名扩展超类实现接口{ // 类体 } 若要实现多个接口,接口之间用逗号分隔。 实现接口时,extend...
    编程 发布于2024-11-08
  • 检查 Effect-TS 选项中的元素:实用指南
    检查 Effect-TS 选项中的元素:实用指南
    Effect-TS 提供了检查 Option 是否包含特定值的方法。这些函数允许您使用自定义等价函数或默认等价来确定选项中是否存在值。在本文中,我们将探讨用于检查选项中元素的两个关键函数:O.containsWith 和 O.contains. 示例 1:使用 O.containsW...
    编程 发布于2024-11-08
  • Python 面向对象编程简介
    Python 面向对象编程简介
    Python 编程语言 Python 是一种解释型、面向对象的编程语言。由于其高级内置数据结构和动态类型,它在快速开发新应用程序以及编写脚本代码以组合用不同语言编写的现有组件方面很受欢迎。 Python简单易学的语法强调可读性,从而降低了长期程序维护的成本和复杂性。它支持各种包含代...
    编程 发布于2024-11-08
  • 最佳软件比较中的顶级数据科学工具
    最佳软件比较中的顶级数据科学工具
    介绍 到 2024 年,数据科学将通过使用复杂的分析、人工智能和机器学习推动决策,继续改变业务。随着对熟练数据科学家的需求不断增加,对能够加快操作、提高生产力并提供可靠见解的强大工具的需求也在增加。但是,有这么多可用的选项,目前哪种软件最适合专业人士? 这项比较研究探讨了 2024...
    编程 发布于2024-11-08
  • 我如何将应用程序性能提高到
    我如何将应用程序性能提高到
    ⌛ 回顾时间 在我的上一篇博客中,我谈到了如何在短短 2 周内将应用程序大小从 75MB 减少到 34MB(查看!)。但这还不是全部,我还将我们应用程序的整体性能提高了 80%?. 让我们来看看如何!! ?传说 经过简单的一轮浏览后,我发现我们的应用程序中存在一些导...
    编程 发布于2024-11-08
  • Django 查询集可以通过模型属性过滤吗?
    Django 查询集可以通过模型属性过滤吗?
    按模型属性过滤 Django 查询集Django 模型上的查询通常使用标准过滤器根据预定义字段值选择特定实例。但是,如果您需要根据模型中定义的自定义属性进行过滤,该怎么办?您可以通过模型属性过滤查询集吗?不幸的是,Django 的过滤器主要运行在数据库级别,将它们转换为 SQL 命令以有效地检索数据...
    编程 发布于2024-11-08
  • 尽管配置正确,为什么我无法在 Laravel 中发送 TLS 电子邮件?
    尽管配置正确,为什么我无法在 Laravel 中发送 TLS 电子邮件?
    无法发送 TLS 电子邮件:解决 Laravel 证书验证错误尽管启用了不太安全的 Gmail 设置并正确配置了 Laravel 的 .env 文件,您在发送 TLS 电子邮件时遇到证书验证失败。错误消息表明 SSL 操作失败并且无法验证服务器证书。要解决此问题,如果您的操作系统没有自动管理受信任的...
    编程 发布于2024-11-08
  • 使用 Wasmtime 和 Wasm3 将 Golang 编译为 Wasm 时出现错误如何解决?
    使用 Wasmtime 和 Wasm3 将 Golang 编译为 Wasm 时出现错误如何解决?
    使用 Wasmtime 和 Wasm3 将 Golang 编译为 Wasm 时出现错误使用 GOOS=js 将 Golang 代码编译为 WebAssembly (Wasm) GOARCH=wasm go使用 Wasmtime 或 Wasm3 执行时,build -o main.wasm 可能会导致...
    编程 发布于2024-11-08
  • 如何访问 Iframe 的当前位置?
    如何访问 Iframe 的当前位置?
    访问 iframe 的当前位置:挑战和解决方法跨源资源共享 (CORS) 法规在尝试检索 iframe 时带来了重大挑战iframe 的当前位置。此安全措施可防止驻留在不同来源的 JavaScript 代码直接访问页面的 URL。虽然使用 JavaScript 访问 iframe 的 URL 不可行...
    编程 发布于2024-11-08
  • Spring Security 与 JWT
    Spring Security 与 JWT
    In this article, we will explore how to integrate Spring Security with JWT to build a solid security layer for your application. We will go through ea...
    编程 发布于2024-11-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3