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

阅读: 评论:0

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

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

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

本文发布于:2024-01-27 19:52:38,感谢您对本站的认可!

本文链接:https://www.4u4v.net/it/17063563602294.html

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。

标签:自适应   颜色   CSS   SVG
留言与评论(共有 0 条评论)
   
验证码:

Copyright ©2019-2022 Comsenz Inc.Powered by ©

网站地图1 网站地图2 网站地图3 网站地图4 网站地图5 网站地图6 网站地图7 网站地图8 网站地图9 网站地图10 网站地图11 网站地图12 网站地图13 网站地图14 网站地图15 网站地图16 网站地图17 网站地图18 网站地图19 网站地图20 网站地图21 网站地图22/a> 网站地图23