如何在移动设备上实现悬停效果?在移动设备上,我希望桌面端悬停时显示的内容能够自动显示。

3
我想使用@media (hover: hover),但我无法使其工作。我在一行中有三个图片,当鼠标悬停在上面时,会显示文本叠加。目前,每当我添加@media (hover: hover)并切换到移动视图时,图片保持不变。我要么想让@media (hover: hover)起作用,要么尝试其他方法。这是我第一次设计网站并使用堆栈溢出,所以我有些力不从心。我没有看到已发布的任何问题与我的问题足够相似,可以帮助我实现我的目标。以下是我的CSS代码。
    .card-container
{
    margin-top: 10%;
}

.card-container h1
{
    font-family: merriweather;
}

.card
{
    position: relative;
    overflow: hidden;
}

.card:before
{
    position: absolute;
    content: '';
    width: 80%;
    height: 220%;
    background: rgba(217, 153, 35, 0.7);
    top: -50%;
    left: -100%;
    z-index: 1;
    transform: rotate(25deg);
    transform-origin: center top 0;
    transition: .5s;
}

.card:hover:before
{
    left: 10%;
}

.card img
{
    width: 100%;
    height: auto;
}

.card-text
{
    width: 100%;
    padding: 0 20px;
    position: absolute;
    top: -100%;
    color: #ffff;
    left: 0;
    z-index: 2;
    transition: 1.1s;
}

.card-text h3
{
    font-family: merriweather;
    font-weight: 900;
}

.card-text h5
{
    font-family: lora;
}

.card:hover .card-text
{
    top: 80px;
}

1
不要使用 @media (hover: hover),而应该使用 @media (max-width: xxx) - Amaury Hanser
2个回答

1

您只需要在响应式媒体查询中使用组合CSS选择器属性。

例如- .class:hover, .class:active, .class:focus

请参考此链接以获取实时演示并了解详细信息。 https://jsfiddle.net/yudizsolutions/nc2fh7kp/

ol,
ul {
  list-style: none;
}

li {
  display: inline-block;
  padding: 20px 0 20px;
  vertical-align: middle;
}

a:hover,
a:focus,
a:active {
  color: #999;
  text-decoration: none;
}

a {
  text-decoration: none;
  transition: color 0.1s, background-color 0.1s;
  position: relative;
  display: block;
  padding: 16px 0;
  margin: 0 12px;
  letter-spacing: 1px;
  font-size: 12px;
  line-height: 16px;
  font-weight: 900;
  text-transform: uppercase;
  transition: color 0.1s, background-color 0.1s, padding 0.2s ease-in;
  color: #000;
}

a::before {
  content: '';
  display: block;
  position: absolute;
  bottom: 3px;
  left: 0;
  height: 3px;
  width: 100%;
  background-color: #000;
  transform-origin: right top;
  transform: scale(0, 1);
  transition: color 0.1s, transform 0.2s ease-out;
}

a:active::before {
  background-color: #000;
}

a:hover::before,
a:focus::before {
  transform-origin: left top;
  transform: scale(1, 1);
}
<nav>
  <ul>
    <li class="item"><a href="#">link 1</a></li>
    <li class="item"><a href="#">link 2</a></li>
    <li class="item"><a href="#">link 3</a></li>
    <li class="item"><a href="#">link 4</a></li>
    <li class="item"><a href="#">link 5</a></li>
  </ul>
</nav>


1
在移动设备上,您需要结合hoveractive来悬停元素。
因此,您需要在CSS中声明如下。
.card:hover, .card:active{
//your hover effect.
}

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接