【发布时间】:2020-06-23 08:17:15
【问题描述】:
我目前正面临使用 before 和 after 伪元素淡入导航项的问题。
当我悬停导航项时,它必须将其背景颜色从白色更改为蓝色。没什么疯狂的。 但它还必须显示两个背景图像,分别将 ::before 伪元素从 0 更改为 1 并将 ::after 伪元素从 0 更改为 1。
问题是虽然我设置了相同的过渡持续时间,但元素的淡入淡出行为与自身的背景颜色过渡相比有点不同。
您还可以通过快速进出鼠标来“玩”悬停 (jsfiddle) 以更清楚地查看问题。
如果有人能帮我解决这个谜团,将不胜感激:)
这是我的 jsfiddle:https://jsfiddle.net/5qnw8ke4/
这里是过渡问题的截图:screen capture
a {
display: block;
width: 61px;
height: 67px;
margin: 50px;
background-color: #fff;
text-align: center;
font-family: "Roboto", sans-serif;
text-decoration: none;
line-height: 67px;
color: #259cff;
position: relative;
transition: background-color 0.3s, color 0.3s;
}
a::before, a::after {
opacity: 0;
height: 100%;
position: absolute;
top: 0;
content: "";
-webkit-transition: opacity 0.3s,width 0.3s,left 0.3s,right 0.3s;
transition: opacity 0.3s,width 0.3s,left 0.3s,right 0.3s;
}
a::before {
width: 12px;
left: -12px;
background: url("https://svgshare.com/i/J61.svg") no-repeat 0;
background-size: auto 100%;
}
a::after {
width: 12px;
right: -12px;
background: url("https://svgshare.com/i/J4j.svg") no-repeat 100%;
background-size: auto 100%;
}
a:hover {
background-color: #259cff;
color: #fff;
}
a:hover::before, a:hover::after {
opacity: 1;
width: 17px;
}
a:hover::before {
left: -17px;
}
a:hover::after {
right: -17px;
}
<a href="#">My link</a>
【问题讨论】:
标签: css css-transitions background-image background-color pseudo-element