У меня есть несколько карточек, и я хочу изменить свойства 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>