CSS 修改SVG颜色并且宽高自适应

2024-01-24 16:10

本文主要是介绍CSS 修改SVG颜色并且宽高自适应,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

需求

  1. 下图中的图案和文字根据网站的主题色更新
  2. 缩放屏幕大小时,图片可以根据屏幕大小自适应

请添加图片描述请添加图片描述

解决过程

  1. 刚开始用的 img 标签设置图片,可以自动自适应,但修改图片颜色需要滤镜,感觉比较复杂,所以放弃了此方法。
  2. 想用字体图标是做,但还需要设计去重新帮忙弄,设计又很忙所以暂搁了此方法。
  3. 最后用svg, 简单的svg 改变颜色很简单,但自适应却让我想了一会,最后想着用最笨的办法:
    裹一个 relative 定位的 div,底下放一个宽度100%透明的 img,上面覆盖一个 宽高100% 的 absolute 的 svg 图片,代码如下:
<style>
.svg-box{position: relative;
}
.svg-box img{opacity: 0;
}
.svg-box .svg-icon{position: absolute;left: 0;top: 0;width: 100%;height: 100%;
}
</style><div class="svg-box"><img src="multiple.png" width="100%"/><svg width="198" height="206" viewBox="0 0 198 206" fill="none" xmlns="http://www.w3.org/2000/svg" class="svg-icon"><rect x="8.5" y="24.5" width="181" height="181" rx="3.5" fill="#fff" stroke="#E6007A"/><rect x="4.5" y="12.5" width="189" height="189" rx="3.5" fill="#fff" stroke="#E6007A"/><rect x=".5" y=".5" width="197" height="197" rx="3.5" fill="#fff" stroke="#E6007A"/><path fill-rule="evenodd" clip-rule="evenodd" d="M113.142 113.142c7.811-7.81 7.811-20.474 0-28.284-7.81-7.81-20.474-7.81-28.284 0-7.81 7.81-7.81 20.474 0 28.284 7.81 7.811 20.474 7.811 28.284 0zM109 99a2 2 0 0 1-2 2h-6v6a2 2 0 0 1-4 0v-6h-6a2 2 0 0 1 0-4h6v-6a2 2 0 1 1 4 0v6h6a2 2 0 0 1 2 2z" fill="#E6007A"/></svg>
</div>

后来发现 去掉透明 img 和定位,仍然有效,代码见下方解决方法

解决方法

HTML

<div class="svg-box"><svg width="198" height="206" viewBox="0 0 198 206" fill="none" xmlns="http://www.w3.org/2000/svg" class="svg-icon"><rect x="8.5" y="24.5" width="181" height="181" rx="3.5" fill="#fff" stroke="#E6007A"/><rect x="4.5" y="12.5" width="189" height="189" rx="3.5" fill="#fff" stroke="#E6007A"/><rect x=".5" y=".5" width="197" height="197" rx="3.5" fill="#fff" stroke="#E6007A"/><path fill-rule="evenodd" clip-rule="evenodd" d="M113.142 113.142c7.811-7.81 7.811-20.474 0-28.284-7.81-7.81-20.474-7.81-28.284 0-7.81 7.81-7.81 20.474 0 28.284 7.81 7.811 20.474 7.811 28.284 0zM109 99a2 2 0 0 1-2 2h-6v6a2 2 0 0 1-4 0v-6h-6a2 2 0 0 1 0-4h6v-6a2 2 0 1 1 4 0v6h6a2 2 0 0 1 2 2z" fill="#E6007A"/></svg>
</div>

CSS

:root{--mainColor: #e6007a;
}
.svg-box .svg-icon{width: 100%;height: 100%;
}
.svg-icon rect{stroke:var(--mainColor);
}
.svg-icon path{fill:var(--mainColor);
}

JS: 修改主题色

let root = document.querySelector(":root");
root.style.setProperty("--mainColor", '你想设置的主题颜色,如:#3498db');

我的个人博客,有空来坐坐

https://www.wangyanan.online

这篇关于CSS 修改SVG颜色并且宽高自适应的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/640226

相关文章

CSS place-items: center解析与用法详解

《CSSplace-items:center解析与用法详解》place-items:center;是一个强大的CSS简写属性,用于同时控制网格(Grid)和弹性盒(Flexbox)... place-items: center; 是一个强大的 css 简写属性,用于同时控制 网格(Grid) 和 弹性盒(F

CSS实现元素撑满剩余空间的五种方法

《CSS实现元素撑满剩余空间的五种方法》在日常开发中,我们经常需要让某个元素占据容器的剩余空间,本文将介绍5种不同的方法来实现这个需求,并分析各种方法的优缺点,感兴趣的朋友一起看看吧... css实现元素撑满剩余空间的5种方法 在日常开发中,我们经常需要让某个元素占据容器的剩余空间。这是一个常见的布局需求

CSS Anchor Positioning重新定义锚点定位的时代来临(最新推荐)

《CSSAnchorPositioning重新定义锚点定位的时代来临(最新推荐)》CSSAnchorPositioning是一项仍在草案中的新特性,由Chrome125开始提供原生支持需... 目录 css Anchor Positioning:重新定义「锚定定位」的时代来了! 什么是 Anchor Pos

CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比

《CSS中的Static、Relative、Absolute、Fixed、Sticky的应用与详细对比》CSS中的position属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布... css 中的 position 属性用于控制元素的定位方式,不同的定位方式会影响元素在页面中的布局和层叠关

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

使用Python和OpenCV库实现实时颜色识别系统

《使用Python和OpenCV库实现实时颜色识别系统》:本文主要介绍使用Python和OpenCV库实现的实时颜色识别系统,这个系统能够通过摄像头捕捉视频流,并在视频中指定区域内识别主要颜色(红... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间详解

SQL Server修改数据库名及物理数据文件名操作步骤

《SQLServer修改数据库名及物理数据文件名操作步骤》在SQLServer中重命名数据库是一个常见的操作,但需要确保用户具有足够的权限来执行此操作,:本文主要介绍SQLServer修改数据... 目录一、背景介绍二、操作步骤2.1 设置为单用户模式(断开连接)2.2 修改数据库名称2.3 查找逻辑文件名

OpenCV实现实时颜色检测的示例

《OpenCV实现实时颜色检测的示例》本文主要介绍了OpenCV实现实时颜色检测的示例,通过HSV色彩空间转换和色调范围判断实现红黄绿蓝颜色检测,包含视频捕捉、区域标记、颜色分析等功能,具有一定的参考... 目录一、引言二、系统概述三、代码解析1. 导入库2. 颜色识别函数3. 主程序循环四、HSV色彩空间

苹果macOS 26 Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色

《苹果macOS26Tahoe主题功能大升级:可定制图标/高亮文本/文件夹颜色》在整体系统设计方面,macOS26采用了全新的玻璃质感视觉风格,应用于Dock栏、应用图标以及桌面小部件等多个界面... 科技媒体 MACRumors 昨日(6 月 13 日)发布博文,报道称在 macOS 26 Tahoe 中

全面解析HTML5中Checkbox标签

《全面解析HTML5中Checkbox标签》Checkbox是HTML5中非常重要的表单元素之一,通过合理使用其属性和样式自定义方法,可以为用户提供丰富多样的交互体验,这篇文章给大家介绍HTML5中C... 在html5中,Checkbox(复选框)是一种常用的表单元素,允许用户在一组选项中选择多个项目。本