2013-10-11 3 views
1

Вы можете увидеть это здесь ...Почему содержание в пределах этого Div завинтить Vertical Alignment

http://jsfiddle.net/cf9Hu/

<div class="container"> 
     <div class="outer"> 
      <div> 
       Blah 
       <br /> 
       Blah 
      </div> 
      <div class="inner"> 
       x 
      </div> 
     </div> 
     <div class="outer"> 
      <div>Blah</div> 
      <div class="inner"> 
       x 
      </div> 
     </div> 
     <div class="outer"> 
      <div>Blah</div> 
      <div class="inner"> 
       x 
      </div> 
     </div>  
    </div> 

и вот мой CSS ...

.container{ 
    width:100%; 
    text-align:center; 
    border:solid 1px black; 
} 

.outer { 
    width: 100px; 
    height: 100px; 
    background-color: green; 
    display:inline-block; 
    position: relative; 
} 
.inner { 
    position: absolute; 
    right: 0px; 
    bottom: 0px; 
} 

ответ

4

Если вы хотите его исправить, используйте вертикальное выравнивание.

.outer { 
    width: 100px; 
    height: 100px; 
    background-color: green; 
    display: inline-block; 
    position: relative; 
    vertical-align: top; 
} 

Или, вы можете использовать «встроенный стол» для отображения, чтобы получить тот же результат

.outer { 
    width: 100px; 
    height: 100px; 
    background-color: green; 
    display: inline-table; 
    position: relative; 
} 
+0

Вертикальное выравнивание - это свойство, в котором вы отсутствовали @ek_ny. Однако относительная позиция не требуется. – Brant

+0

Ему нужно «положение: относительное»; для его «внутреннего» div, который использует абсолютное позиционирование. –

+0

Ах, да .. Спасибо, Йосеп. – Brant

1

Вы можете либо дать вертикальное выравнивание для вас Outer Дива

"vertical-align: top; OR vertical-align: bottom;" 

.outer { 
    width: 100px; 
    height: 100px; 
    background-color: green; 
    display:inline-block; 
    position: relative; 
    vertical-align: top; 
} 

или вы может изменить «display: inline-block»; до "float:left;"

.outer { 
    width: 100px; 
    height: 100px; 
    background-color: green; 
    float:left; 
    position: relative; 
} 

Надеюсь, это поможет!

Смежные вопросы