CSS将图像置于div中间:隐藏溢出

时间:2012-06-26 16:39:03

标签: css image center

我想在div容器内放置宽度为200px且未知高度的个人资料图片。 div为150px x 150px。 img应该水平居中,每侧都隐藏着出血。我不能让它工作,未知的高度弄乱它,因为img宽度的出现方式取决于高度。 - 横向img将获得更高的宽度以填充高度差并保持img成比例。如果是肖像图像,宽度应为150px作为div ...

观看图片:http://s18.postimage.org/52hfcc5h3/Sk_rmavbild_2012_06_26_kl_19_12_49.png

#profilePicture {
    display: block;
    float: left;
    width: 150px;
    height: 150px;
    overflow: hidden;
    position: relative;
    margin: 0 auto;

    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
}
#profilePicture img {
    min-width: 150px;
    min-height: 150px;
    left: 50%;
    margin-left: -100px;
    top: 50%;
    margin-top: -100px;
    position:absolute;

    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    border-radius: 5px;
}

2 个答案:

答案 0 :(得分:3)

您是否考虑过使用背景图片?这会让事情变得更容易。

.img {
    overflow: hidden;
    background-image: url('/xyz.jpg');
    background-size: cover;
    background-position: center;
}

这是小提琴 - > http://jsfiddle.net/haNj3/1/

答案 1 :(得分:0)

我认为你想要做的是this

.main{
width:150px;
margin: 0 auto;
overflow:visible;
position: relative;
height: 200px;
outline: 1px solid blue;
}

img.absolute{
width: 200px;
left: 50%;
margin-left: -100px;
margin-top: 0;
position:relative;
outline: 1px solid red; 
}

我认为在这种情况下不需要使用绝对定位。