У меня есть несколько карточек, и я хочу изменить свойства border-color
и pointer-events
, когда пользователь наводит тег span
, который находится внутри тега button
.
Это не проблема, если яиспользуйте тег a
, см. первую карту слева:
https://codepen.io/anon/pen/JzzEvj
Однако при использовании шаблона PRG с form
и button
изменяется указатель события и border-bottom
цвет при наведении не работает с Firefox .(См. Вторую карточку справа)
Есть идеи, как это исправить в Firefox?
Желаемый результат см. Карточка слева:
- Курсор должениметь состояние
pointer
при наведении курсора на изображение - курсор должен иметь состояние
pointer
при наведении курсора на карту - цвет заголовка карты
border-bottom
должен менять цвет при наведении курсора на карту
Я трачу много времени на эту проблему, но нашел только решение https://codepen.io/anon/pen/PLLWxJ, которое не совсем точнотот же , потому что
- цвет заголовка карты
border-bottom
меняется при наведении любой часть карты. - все части карты выглядят кликабельными при зависании.Состояние курсора должно изменяться только на
pointer
при наведении курсора на изображение или заголовок карты.
a {
text-decoration: none;
}
.product-cards-wrapper {
background: #fff;
padding: 64px 0;
}
.product-cards {
display: flex;
justify-content: center;
flex-wrap: wrap;
}
.product-card {
border: 1px dotted #ccc;
cursor: default;
margin: 0 16px 32px;
width: 250px;
text-align: center;
}
.product-card-img-wrapper {
align-items: center;
cursor: pointer;
display: flex;
justify-content: center;
height: 150px;
line-height: 0;
margin-bottom: 16px;
}
.product-card-heading {
border-bottom: 1px solid #e5e5e5;
color: #2bb3f0;
display: inline;
font-family: sans-serif;
font-size: 18px;
font-weight: 700;
line-height: 1.6;
text-align: center;
transition: border-color .2s;
}
.product-card-heading:hover {
border-color: #2bb3f0;
cursor: pointer;
}
.product-card-label {
background: #fee5ad;
border-radius: 99px;
color: rgba(0, 0, 0, .54);
cursor: text;
font-family: sans-serif;
font-size: 14px;
font-weight: 600;
margin-top: 4px;
padding: 2px 10px;
}
.product-card>button {
background: 0;
border: 0;
padding: 0;
width: 100%;
}
.product-card-heading {
border-bottom: 1px solid #e5e5e5;
color: #2bb3f0;
cursor: pointer;
transition: border-color .2s;
}
.product-card button .product-card-img-wrapper,
.product-card button .product-card-heading {
cursor: pointer;
}
.product-card button .product-card-heading:hover {
border-color: #2bb3f0;
}
.product-card-labels {
display: block;
font-family: sans-serif;
}
<section class=product-cards-wrapper>
<div class=product-cards>
<a class=product-card href=#>
<div class=product-card-img-wrapper>
<img src=https://via.placeholder.com/160x150 alt="">
</div>
<div class=product-card-heading>First Card</div>
<div class=product-card-labels><span class=product-card-label>Label</span></div>
</a>
<form class=product-card action=# method=post target=_blank>
<button name=l value=123>
<span class=product-card-img-wrapper>
<img src=https://via.placeholder.com/120x150 alt="">
</span>
<span class=product-card-heading>Second Card</span>
<span class=product-card-labels><span class=product-card-label>Label</span></span>
</button>
</form>
</div>
</section>