Как центрировать элемент по горизонтали и вертикали

Я пытаюсь центрировать содержимое своих вкладок по вертикали, но когда я добавляю стиль CSS display:inline-flex, горизонтальное выравнивание текста исчезает.

Как сделать выравнивание текста x и y для каждой из моих вкладок?

* { box-sizing: border-box; }
#leftFrame {
  background-color: green;
  position: absolute;
  left: 0;
  right: 60%;
  top: 0;
  bottom: 0;
}
#leftFrame #tabs {
  background-color: red;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 25%;
}
#leftFrame #tabs div {
  border: 2px solid black;
  position: static;
  float: left;
  width: 50%;
  height: 100%;
  text-align: center;
  display: inline-flex;
  align-items: center;
}
<div id=leftFrame>
  <div id=tabs>
    <div>first</div>
    <div>second</div>
  </div>
</div>

Ответ 1

.container {
    position: absolute;
    top: 50%;
    left: 50%;
    -moz-transform: translateX(-50%) translateY(-50%);
    -webkit-transform: translateX(-50%) translateY(-50%);
    transform: translateX(-50%) translateY(-50%);
}
<div class="container">
    <span>I'm vertically/horizontally centered!</span>
</div>

Ответ 2

Если CSS3 является опцией (или у вас есть резерв), вы можете использовать transform:

.center {
    right: 50%;
    bottom: 50%;
    transform: translate(50%,50%);
    position: absolute;
}

В отличие от первого подхода выше, вы не хотите использовать левый: 50% с отрицательным переводом, потому что ошибка переполнения в IE9+. Используйте положительное правое значение, и вы не увидите горизонтальные полосы прокрутки.

Ответ 3

Лучший способ центрировать прямоугольник как по вертикали, так и по горизонтали, это использовать два контейнера:

Внешний контейнер:

  • должен иметь display: table;

Внутренний контейнер:

  • должен иметь display: table-cell;
  • должен иметь vertical-align: middle;
  • должен иметь text-align: center;

Контент окно:

  • должен иметь display: inline-block;
  • следует настроить горизонтальное выравнивание текста, если вы не хотите, чтобы текст был центрирован

Демо:

body {
    margin : 0;
}

.outer-container {
    display: table;
    width: 80%;
    height: 120px;
    background: #ccc;
}

.inner-container {
    display: table-cell;
    vertical-align: middle;
    text-align: center;
}

.centered-content {
    display: inline-block;
    text-align: left;
    background: #fff;
    padding : 20px;
    border : 1px solid #000;
}
<div class="outer-container">
   <div class="inner-container">
     <div class="centered-content">
        Center this!
     </div>
   </div>
</div>

Ответ 4

Запустите этот фрагмент кода и посмотрите вертикальный и горизонтально выровненный div.

html,
body,
.container {
  height: 100%;
  width: 100%;
}
.container {
  display: flex;
  align-items: center;
  justify-content: center;
}
.mydiv {
  width: 80px;
}
<div class="container">
  <div class="mydiv">h & v aligned</div>
</div>

Ответ 5

Вот как можно использовать 2 простых свойства flex, чтобы центрировать n делителей на оси 2:

  • Установите высоту вашего контейнера: здесь тело должно быть не менее 100vh.
  • align-items: center будет вертикально центрировать блоки
  • justify-content: space-around распределит свободное горизонтальное пространство вокруг элементов

.

body {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: space-around;
}
<div>foo</div>
<div>bar</div>

Ответ 6

Самое простое и чистое решение для меня - использование свойства CSS3 "transform":

.container {
  position: relative;
}

.container a {
  position: absolute;
  top: 50%;
  transform: translate(0,-50%);
}
<div class="container">
  <a href="#">Hello world!</a>
</div>

Ответ 7

    .align {
        display: flex;
        width: 400px;
        height: 400px;
        border: solid 1px black;
        align-items: center;
        justify-content: space-around;
    }
    .align div:first-child {
        width: 20px;
        height: 20px;
        background-color: red;
        position: absolute; 
    }
    .align div {
        width: 20px;
        height: 20px;
        background-color: blue;
    }
    <div class='align'>
        <div></div>
        <div></div>
        <div></div>
        <div></div>
        <div></div>
        <div></div>
    </div>

Ответ 8

Другой подход - использовать таблицу:

<div style="border:2px solid #8AC007; height:200px; width:200px;">
  <table style="width:100%; height:100%">
    <tr style="height:100%">
      <td style="height:100%; text-align:center">hello, multiple lines here, this is super long, and that is awesome, dude</td>
    </tr>
  </table>
</div>

Ответ 9

чтобы центрировать Div на странице проверить ссылку на скрипт

#vh {
    border-radius: 15px;
    box-shadow: 0 0 8px rgba(0, 0, 0, 0.4);
    padding: 25px;
    width: 200px;
    height: 200px;
    background: white;
    text-align: center;
    margin: auto;
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
}
<div id="vh">Div to be aligned vertically</div>

Ответ 10

Ниже представлен подход Flex-box для получения желаемого результата.

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <meta name="viewport" content="width=device-width">
  <title>Flex-box approach</title>
<style>
  .tabs{
    display: -webkit-flex;
    display: flex;
    width: 500px;
    height: 250px;
    background-color: grey;
    margin: 0 auto;
    
  }
  .f{
    width: 200px;
    height: 200px;
    margin: 20px;
    background-color: yellow;
    margin: 0 auto;
    display: inline; /*for vertically aligning */
    top: 9%;         /*for vertically aligning */
    position: relative; /*for vertically aligning */
  }
</style>
</head>
<body>

    <div class="tabs">
        <div class="f">first</div>
        <div class="f">second</div>        
    </div>

</body>
</html>

Ответ 11

Для вертикального и горизонтального центрирования элемента мы также можем использовать приведенные ниже свойства.

Это свойство CSS alignments-items по вертикали и принимает следующие значения:

flex-start: элементы выравниваются в верхней части контейнера.

flex-end. Элементы выравниваются в нижней части контейнера.

центр: элементы выравниваются в вертикальном центре контейнера.

базовый уровень. Элементы отображаются на базовой линии контейнера.

растянуть. Элементы растягиваются, чтобы соответствовать контейнеру.

Это свойство CSS justify-content, которое выравнивает элементы по горизонтали и принимает следующие значения:

flex-start. Элементы выравниваются в левой части контейнера.

flex-end: элементы выравниваются с правой стороны контейнера.

центр. Элементы выравниваются в центре контейнера.

пробел между: элементы отображаются с равным интервалом между ними.

space-around: элементы отображаются с равным интервалом вокруг них.

Ответ 12

  • Подход 6

/*Change units to "%", "px" or whatever*/

#wrapper{
  width: 50%;
  height: 70vh;
  background: rgba(0,0,0,.5);
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  margin: auto;
}
#left{
  width: 50%;
  height: 50vh;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  background: red;
}
#right{
  width: 50%;
  height: 50vh;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  margin: auto;
  background: green;
}
.txt{
  text-align: center;
  line-height: 50vh;
}
<div id="wrapper">
   <div id="left" class="txt">Left</div>
   <div id="right" class="txt">Right</div>
</div>

Ответ 13

Просто сделайте сверху, снизу, слева и справа на 0.

<html>
<head>
<style>
<div> 
{
position: absolute;
margin: auto;
background-color: lightblue;
width: 100px;
height :100px;
padding: 25px;
top :0;
right :0;
bottom:0;
left:0;
}


</style>
</head>
<body>

<div> I am in the middle</div>

</body>
</html>

Ответ 14

Сетка css подход

#wrapper {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 0;
    left: 0;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: repeat(3, 1fr);
}
.main {
    background-color: #444;
}
<div id="wrapper">
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box"></div>
    <div class="box main"></div>
</div>

Ответ 15

Вы можете добиться этого с помощью CSS (ваш элемент display:inline-grid + grid-auto-flow: row;) Grid и Flex Box (display:flex; родительского элемента display:flex;),

Смотрите ниже фрагмент

#leftFrame {
  display: flex;
  height: 100vh;
  width: 100%;
}

#tabs {
  display: inline-grid;
  grid-auto-flow: row;
  grid-gap: 24px;
  justify-items: center;
  margin: auto;
}

html,body {
  margin:0;
  padding:0;
}
<div>
<div id=leftFrame>
  <div id=tabs>
    <div>first</div>
    <div>second</div>        
  </div>
</div>
</div>

Ответ 16

Самый простой способ центрировать div как вертикально, так и горизонтально:

<div style="display: table; width: 200px; height: 200px; border: 1px solid black;">
    <div style="display: table-cell; vertical-align: middle; text-align: center;">
        Text Here
    </div>
</div>

Ответ 17

Это должно работать

.center-div {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    min-height: 100vh;
}
<div class="center-div">Center Div</div>

Ответ 18

Источник Ссылка

Способ 1) Тип отображения flex

.child-element{
     display: flex;
     justify-content: center;
     align-items: center;
}

Method 2) 2D Transform

.child-element {
   top: 50%;
   left: 50%;
   transform: translate(-50% , -50%);
   position: absolute;
}

Смотрите другие методы здесь

Ответ 19

Просто ! Используйте display flex на контейнере и margin auto для текста !!!!

#hood{

 width : 300px;
 height: 100px;
 border: solid 1px #333333;
 display: flex; 
}

#hood span{

  margin: auto
}



<html>
<head></head>
    <body>
        <div id="hood">
            <span> I Am Centered</span>
        </div>
    </body>
</html>

Демонстрация: https://jsfiddle.net/ay95f08g/

Протестировано: Safari, Chrome, Firefox и Opera на MacOs в Мохаве. (все последние обновления 25 февраля 2019 г.)