Как с помощью css создать таблицу по центру экрана?

Как на странице, с помощью css, создать таблицу по центру экрана (по высоте и ширине)?
Таблица должна автоматически подстраиваться размер под содержимого.
Это возможно на css без js?

PS
Впрочем можно и div. Но как вы видите, он должен быть фиксированного размера.
А мне нужно, чтобы размер подстраивался под содержимое.
/* Окно ввода логина и пароля */
.log_window
{
top: 50%; /* Отступ в процентах от верхнего края окна */
left: 50%; /* Отступ в процентах от левого края окна */
/* width: 450px;  Ширина блока */
width:240px; /* Ширина блока */
height: 120px; /* Высота блока */
position: absolute; /* Абсолютное позиционирование блока */
margin-top: -60px; /* Отрицательный отступ от верхнего края страницы, должен равняться половине ширины блока со знаком минус */
margin-left: -120px; /* Отрицательный отступ от левого края страницы, должен равняться половине высоты блока со знаком минус */
}
  • Вопрос задан
  • 1456 просмотров
Пригласить эксперта
Ответы на вопрос 4
PavelMonro
@PavelMonro
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
width:100%;
max-width:500px;
height: 100%;
max-height:300px;


Что то вроде того
Ответ написан
bogdan_uman
@bogdan_uman
шлЫмазл неукЪ-поцЪ
Ну мне больше нравится вариант с flex
28aaf2401dae448abfc3fbe53ff87dbf.png
Вот и сама верстка на slim
doctype html
html
  head
    title Slim Examples
    meta name="keywords" content="template language"
    link rel="stylesheet" type="text/css" href="../session.css" media="screen"
  body
    / Вход пользователя
    #main_log_in
      form 
        span Вхід в портал
        div : input *{ type: :text, name: :username, placeholder: 'Користувач...' }
        div : input *{type: :password, name: :password, placeholder: 'Пароль...' }
        button


а вот и стили на Sass
$ffIcon: 'Glyphicons Halflings';

@import 'application';

#main_log_in {
  height: 100vh;
  width: 100vw;
  display: flex;
  justify-content: center;
  align-items: center;
  background-color: #666666;

  form {
    display: inline-block;
    width: 500px;
    border-radius: 3px;
    background-color: white;

    /* Заголовок */
    span {
      display: block;
      width: 100%;
      padding-left: 15px;
      line-height: 43px;
      font-size: 16px;
      background-color: #d9edf7;
      color: #31708f;
      border-radius: 3px 3px 0 0;
    }

    /* Поля ввода с иконами */
    div {
      margin: 20px 15px;
      position: relative;
      &:before { font-family: $ffIcon; position: absolute; top: 8px; left: 8px; color: #aaa; }

      &:nth-of-type(1):before { content: "\e008"; } /* Иконка для пользователя */
      &:nth-of-type(2):before { content: "\e139"; } /* Иконка для пароля */

      /* Поля ввода с иконами */
      input {
        width: 100%;
        height: 34px;
        border-radius: 3px;
        border: 1px solid #e7e7e7;
        cursor: pointer;
        padding-left: 30px;
        &:hover:enabled { border-color: #aaa; }
      }
    }

    /* Базовая кнопка */
    button {
      height: 34px;
      border-radius: 3px;
      margin: 20px 15px;
      border: 1px solid #2e6da4;
      background-color: #337ab7;
      color: white;
      cursor: pointer;
      &:hover:enabled { background-color: #286090; border-color: #204d74; };
      &:before { content: "Натисність для входу"; };
    }
  }
}
Ответ написан
Комментировать
Lumore
@Lumore
Front-end developer
.log_window {
position: absolute;
width: 100%;
max-width: 240px;
height: 100%;
max-height: 120px;
top: 0;
left: 0;
right: 0;
bottom: 0;
margin: auto;
}
Ответ написан
tolfy
@tolfy
Фирменный стиль
table же :)
Пример на table

p.s. заточено под ваши условия
Ответ написан
Комментировать
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы