Задать вопрос
Elena0394
@Elena0394

Центрирование элемента без родителя?

К примеру такой вариант:
<div class="canvas">
    <div class="circle-container">
      <div class="circle" data-circle="1"></div>
    </div>
  </div>
  <style>
    .canvas {
      width: 50rem;
      height: 50rem;
      position: relative;
    }
    .circle-container {
      position: absolute;
      top: 10rem;
      left: 8rem;
      width: 4rem;
      height: 4rem;
      background-color: bisque;
      display: flex;
      align-items: center;
      justify-content: center;
    }
    [data-circle="1"] {
      width: 4rem;
      height: 4rem;
      border-radius: 50%;
      background-color: blueviolet;
    }
    [data-circle="2"] {
      width: 2rem;
      height: 2rem;
      border-radius: 50%;
      background-color: brown;
    }
  </style>

мне бы хотелось избавится от circle-container, чтоб можно было просто задать координаты например:
position: absolute;
top: 10rem;
left: 10rem;

и каждый круг вставал своим центром на эту координату
  • Вопрос задан
  • 48 просмотров
Подписаться 1 Простой Комментировать
Решения вопроса 1
Stalker_RED
@Stalker_RED
<div class="circle one"></div>
<div class="circle two"></div>
<div class="circle three"></div>
<style>
.circle {
  top: 200px;
  left: 200px; /* вот он, ваш центр */

  transform: translate(-50%, -50%); /* а вот эта магия центрирует */
  position: absolute;
  border-radius: 50%;
}

.one {
  background: red;
  width: 100px;
  height: 100px;
}

.two {
  background: cyan;
  width: 80px;
  height: 80px;
}

.three {
  background: yellow;
  width: 60px;
  height: 60px;
}
</style>
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
noder_ss
@noder_ss
Линуксоид-энтузиаст и SQL разработчик
left:calc(50vw - ширинаpx);
top: calc(50vh - высотаpx)
Ответ написан
Комментировать
Ваш ответ на вопрос

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

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