4

在图像悬停时,我想放大图像并显示一个带有透明背景的 div。

演示:http: //jsfiddle.net/9q4mT/

这是我的代码。在下面的示例中,当我将鼠标悬停在.image类中的图像上时,我想对其进行缩放,并希望.mylink在 div 的中心显示与类的链接。

我可以在悬停时放大,但是当我为 .text 添加样式时,它不再放大图像。

HTML:

<div id="box">
    <div class="image">
        <img src="http://s18.postimg.org/il7hbk7i1/image.png" />
    </div>
    <div class="text">
        <a class="mylink">link</a>
    </div>
</div>

CSS:

#box {
    text-align: center;
    margin: auto;
    width: 250px;
    height: 250px;
    overflow: hidden;
    position: relative;
}

.image img {
    width: 250px;
    height: 250px;
    overflow: hidden;

}
.image img {
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
}

.image img:hover {    
    cursor: pointer;
    transform:scale(1.5);
    -ms-transform:scale(1.5);
    -moz-transform:scale(1.5);
    -webkit-transform:scale(1.5);
    -o-transform:scale(1.5);
}

.text{
    position: absolute;    
    width: 100%;
    height: 100%;
    top: 0;
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
}

.text:hover{
    background: rgba(255, 255, 255, 0.5);    
}

.text a{
    position: absolute;
    top: -100%;   
     -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    -ms-transition: all 1s ease;
    transition: all 1s ease;
}

.text:hover a{    
    top: 50%;
}
4

1 回答 1

7

尝试更改您的 CSS:

  • 添加display:block到您的图像
  • 将首字母添加transform scale(1)到您的 img
  • 将悬停 CSS 规则调整为#box:hover .image img

代码示例http ://codepen.io/jonathan/pen/MYBbMG

.image img {
   display:block;
   width: 250px;
   height: 250px;
}

.image img {        
    -moz-transform:scale(1);
    -webkit-transform:scale(1);
    -o-transform:scale(1);
    transform:scale(1);
    -webkit-transition: all 1s ease;
    -moz-transition: all 1s ease;
    -o-transition: all 1s ease;
    transition: all 1s ease;
}

#box:hover .image img {    
    cursor: pointer;
    -moz-transform:scale(1.5);
    -webkit-transform:scale(1.5);
    -o-transform:scale(1.5);
    transform:scale(1.5);
}
于 2013-11-14T17:25:00.163 回答