通过css改变svg img的颜色
程序员文章站
2022-04-04 14:49:25
需求如下图,hover的时候改变图标颜色,图标为引入的svg img 一般的解决办法有:1.字体图标改变css的color属性;2.js在hover事件中切换图片;3.老一点的方案是hover切换背景? 但是为了更小的开销,一般css为更好的解决方案,svg的颜色是在标签内通过fill属性写死的,所 ......
需求如下图,hover的时候改变图标颜色,图标为引入的svg img
一般的解决办法有:1.字体图标改变css的color属性;2.js在hover事件中切换图片;3.老一点的方案是hover切换背景?
但是为了更小的开销,一般css为更好的解决方案,svg的颜色是在标签内通过fill属性写死的,所以用到了使用了css3滤镜filter
中的drop-shadow。
代码如下:
<section> <div classname={styles.image}> <img src={item.icon} alt="advantage" /> </div> <p>{item.line1}</p> <p>{item.line2}</p> </section>
section{ .image{ display: inline-block; overflow: hidden; } img{ position: relative; left: 0; margin-bottom: .1rem; filter: drop-shadow(#ffffff 80px 0); } &:hover{ background-color: gray; img{ left: -80px; } } }
drop-shadow(h-shadow v-shadow blur spread color):给图像设置一个阴影效果。其中<offset-x> <offset-y>分别设置阴影的偏移量,且必填。具体可以查看w3c的标准
主要的实现原理就是设置需要的阴影效果,并隐藏,hover时切换显示就好,简单,但是之前没怎么了解到
推荐阅读
-
方式显示报错_html/css_WEB-ITnose">
bmp格式的图片在IE中通过方式显示报错_html/css_WEB-ITnose
-
方式显示报错_html/css_WEB-ITnose">
bmp格式的图片在IE中通过方式显示报错_html/css_WEB-ITnose
-
C#通过重写Panel改变边框颜色与宽度的方法
-
svg矢量图标在html中的使用, (知识点:1.通过h5中的css实现点击变色,2.一个svg文件包含多个图标)
-
python之pyqt5通过按钮改变Label的背景颜色方法
-
python之pyqt5通过按钮改变Label的背景颜色方法
-
利用CSS3的特性改变文本选中时的颜色
-
使用CSS3的::selection改变选中文本颜色的方法
-
C#通过重写Panel改变边框颜色与宽度的方法
-
通过jQuery来改变HTML元素CSS样式的方法讲解