html - 关于图片使用scale放大过程中,父元素overflow:hidden失效的问题

查看:471
本文介绍了html - 关于图片使用scale放大过程中,父元素overflow:hidden失效的问题的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

问 题

想做出一个圆形图片,当鼠标hover的时候图片放大。本人做法是父div使用border-radius:50%+overflow:hidden做成圆形,当鼠标hover时,图片使用transform:scale(1.3,1.3)+transition:0.3s实现放大动画,但是使用transition遇到问题是图片在这0.3s的放大时间里会恢复成正方形而不是一直被父div的overflow限制成圆形,放大结束后才会变回圆形,放大过程如下图

想知道如何做才能使图片放大过程中仍然限定在父div的圆形里面,目前找到关键点是transition的有无,没有transition,图片一下子变大,这过程中不会变回正方形。

html

<div class="col-md-3">
   <div class="msg-wrap">
      <a class="msg-link" href="">
        <span class="msg-title">Why Us</span> 
        <img class="msg-img img-responsive" src="img/why_us.jpg" alt=""> 
        </a>
    </div>
</div>

css

.msg-wrap{
    width: 100%;
    height: 100%;
    text-align: center;
    margin: 0 auto;
    overflow: hidden;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    -ms-border-radius: 50%;
    -o-border-radius: 50%;
    border-radius: 50%;
}
.msg-title{
    color: #fff;
    font-weight: bold;
    font-size: 24px;
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 999;
    -webkit-transform: translate(-50%,-50%);
    -ms-transform: translate(-50%,-50%);
    -o-transform: translate(-50%,-50%);
    transform: translate(-50%,-50%);
    -webkit-text-shadow: 1px 1px 5px rgba(0,0,0,0.5);
    -moz-text-shadow: 1px 1px 5px rgba(0,0,0,0.5);
    -ms-text-shadow: 1px 1px 5px rgba(0,0,0,0.5);
    -o-text-shadow: 1px 1px 5px rgba(0,0,0,0.5);
    text-shadow: 1px 1px 5px rgba(0,0,0,0.5);
}

.msg-img{
    -webkit-transition: all 3s;
    -o-transition: all 3s;
    transition: all 3s;
}
.msg-link:hover img{
    -webkit-transform: scale(1.3,1.3);
    -ms-transform: scale(1.3,1.3);
    -o-transform: scale(1.3,1.3);
    transform: scale(1.3,1.3);
}

解决方案

这和 CSS 的 stack context 有关,我在另一个问题中做过问答,点这里

具体到你这个问题,解决方法是给 .msg-wrap 添加 position: relative; z-index: 1 的样式就好了。

Demo

这篇关于html - 关于图片使用scale放大过程中,父元素overflow:hidden失效的问题的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆