-1

我有一些使用边界半径和灰度过滤器的css。我希望边界半径一直到位,但灰度在悬停时消失。

边界半径工作正常,直到我添加灰度,然后它停止工作,只是将图像显示为正方形。在悬停时(当过滤器被移除时)边界半径再次启动。有谁知道我错过了什么?

我已经搜索但找不到答案。

.esg-entry-media {
    width: 250px;
    height: 250px;
    margin: 0 auto;
    -webkit-border-radius: 50% !important;
    border-radius: 50% !important;
    -webkit-filter: grayscale(100%);
    filter: grayscale(100%);
}

.esg-entry-media:hover {
    border: solid 10px #fff !important;
    -webkit-filter: grayscale(0%);
    filter: grayscale(0%);
}

我已经包含了悬停和非悬停状态的图像以供参考。

在此处输入图像描述

4

2 回答 2

0

您可以使用 div 包裹图像并overflow: hidden;在其上放置一个 div 并赋予 div 相同的宽度和高度。然后放border-radius: 50%; 在 div 上。仅在图像上应用灰度。最后改变img做,

div:hover .esg-entry-media{
  filter: grayscale(0)
}

在包装 div 上,

div:hover {
  border: 10px solid *coloryouwant*
}
于 2020-08-11T14:41:47.610 回答
-1

哪个浏览器?对我来说很好(chrome,firefox,safari):

.esg-entry-media {
    width: 250px;
    height: 250px;
    border: 10px solid transparent;
    border-radius: 50%;
    filter: grayscale(100%);
}

.esg-entry-media:hover {
    border-color: #a00;
    filter: grayscale(0%);
}
<img src="http://placekitten.com/200/300" class="esg-entry-media" />

于 2020-08-11T14:50:13.883 回答