Как выровнять div к вершине его родителя, но сохранить его поведение встроенного блока?


171

Смотрите: http://jsfiddle.net/b2BpB/1/

Q: Как вы можете выровнять box1 и box3 по верху родительского div boxContainer?

#boxContainerContainer {
  background: #fdd;
  text-align: center;
}

#boxContainer {
  display: inline-block;
  border: thick dotted #060;
  margin: 0px auto 10px auto;
  text-align: left;
}

#box1 {
  width: 50px;
  height: 50px;
  background: #999;
  display: inline-block;
}

#box2 {
  width: 50px;
  height: 100px;
  background: #999;
  display: inline-block;
}

#box3 {
  width: 50px;
  height: 50px;
  background: #999;
  display: inline-block;
}

Помощь высоко ценится ...

Подтверждение: этот вопрос разветвляется из ответа, ранее предоставленного https://stackoverflow.com/users/20578/paul-d-waite : получение элемента CSS для автоматического изменения размера по ширине содержимого и одновременного центрирования

Ответы:


378

Попробуйте vertical-alignсвойство CSS.

#box1 {
    width: 50px;
    height: 50px;
    background: #999;
    display: inline-block;
    vertical-align: top; /* here */
}

Примените это #box3тоже.


3
Если вы хотите универсальное решение, вы должны применить vertical-align: top;к #boxContainer divселектору. Он применяет стиль ко всем divэлементам внутри boxContainer.
MarthyM

30

Как уже говорили другие, vertical-align: topэто твой друг.

В качестве бонуса здесь разветвленная скрипка с добавленными улучшениями, которые позволяют работать в Internet Explorer 6 и Internet Explorer 7;)

Пример: здесь




-1

Или вы можете просто добавить контент в div и использовать inline-table


зачем добавлять таблицу, когда вы можете использовать вертикальное выравнивание?
Тколсон

1
@tcoulson Я не говорил использовать таблицу, я сказал, что вы можете использовать display: inline-table, которая 3 года назад имела лучшую поддержку браузера и позволяла легко выравнивать по вертикали.
Роберт пошел
Используя наш сайт, вы подтверждаете, что прочитали и поняли нашу Политику в отношении файлов cookie и Политику конфиденциальности.
Licensed under cc by-sa 3.0 with attribution required.