CSS позиционирование вне родительского элемента - PullRequest
2 голосов
/ 17 марта 2020

Привет, сообщество StackOverflow,

Мне нужна ваша помощь для решения проблемы CSS. Для одного из моих проектов мне нужно спроектировать программу просмотра с чистыми временными интервалами CSS. Поскольку картинка всегда лучше длинного текста, вы можете увидеть чуть ниже результат моей работы:

enter image description here

Но вместо места начала / Время окончания в интервале времени, я хотел бы поместить время начала чуть выше верхнего / левого, а время окончания чуть ниже нижнего / правого. Я хотел бы получить такой результат

enter image description here

Вот HTML:

<ul class="day-timeline">
  <li class="time-interval" style="left:4%; width:46%">
    <label class="time start-time">01:00</label>
    <label class="time end-time">12:00</label>
  </li>
  <li class="time-interval" style="left:58%; width:17%">
    <label class="time start-time">14:00</label>
    <label class="time end-time">18:00</label>
  </li>
</ul>

<ul class="day-timeline day-timeline-closed">
  <li class="time-interval closed">
    <label class="time">Closed</label>
  </li>
</ul>

Вот CSS :

* {
  box-sizing: border-box;
}
ul.day-timeline {
  padding: 0;
  border-left: 1px solid black;
  border-right: 1px solid black;
  height: 20px;
  overflow: hidden;
  position: relative;

  &:after {
    content: '';
    width: 100%;
    height: 1px;
    background: black;
    display: block;
    position: relative;
    top: 10px;
  }

  li {
    display: block;
    position: absolute;
    background-color: #bed4a7;
    border: 1px solid green;
    z-index: 1;
    padding-left: 5px;
    border-radius: 3px;
    height: 100%;
    font-weight: bold;
    width: 100%;

    &.closed {
      background-color: lightgray;
      border: 1px solid black;

      label {
        color :black;
      }
    }

    label {
      font-size: 0.75rem;
      color: green;

      &.start-time {
        position: absolute;
        top:-10px;
        left:0;
      }
    }

    label + label {
      &:before {
        content: '-';
        padding: 0 0.25rem;
      }
    }
  }
}

ul.day-timeline-closed {
  border: none;
}

Вы можете увидеть его вживую здесь: https://codepen.io/zannkukai/pen/XWbYXjG.

Несмотря на множество попыток, я никогда не получаю правильный результат: '( CSS -guru может помочь мне решить мою проблему. Я думаю, что проблема в позиционировании label. Но если я использовал position:absolute; top:-10px, то область метки находится за пределами родительской области, и она не отображается: '(

label {
  font-size: 0.75rem;
  color: green;

  &.start-time {
    position: absolute;
    top:-10px;
    left:0;
  }
} 

Большое спасибо

Ответы [ 3 ]

3 голосов
/ 17 марта 2020

удалить overflow: hidden из ul.day-timeline и затем вы можете записать время за пределами родительского элемента.

услышать приписанную ul.day-timeline:

ul.day-timeline {
  padding: 0;
  border-left: 1px solid black;
  border-right: 1px solid black;
  height: 20px;
  //overflow: hidden;
  position: relative;

и слушайте все css:

* {
  box-sizing: border-box;
}
ul.day-timeline {
  padding: 0;
  border-left: 1px solid black;
  border-right: 1px solid black;
  height: 20px;
  //overflow: hidden;
  position: relative;

  &:after {
    content: '';
    width: 100%;
    height: 1px;
    background: black;
    display: block;
    position: relative;
    top: 10px;
  }

  li {
    display: block;
    position: absolute;
    background-color: #bed4a7;
    border: 1px solid green;
    z-index: 1;
    padding-left: 5px;
    border-radius: 3px;
    height: 100%;
    font-weight: bold;
    width: 100%;

    &.closed {
      background-color: lightgray;
      border: 1px solid black;

      label {
        color :black;
      }
    }

    label {
      font-size: 0.75rem;
      color: green;

      &.start-time-first {
        position: absolute;
        top: -15px;
        left: 0px;
      }

      &.end-time-first {
        position: absolute;
        top: 20px;
        right: 5px;
      }
      &.start-time-second {
        position: absolute;
        top: -15px;
        left: 0px;
      }

      &.end-time-second {
        position: absolute;
        top: 20px;
        right: 5px;
      }
    }
  }
}

ul.day-timeline-closed {
  border: none;
}

и класс, который вы должны переименовать, чтобы установить время:

HTML фрагмент кода

  <li class="time-interval" style="left:4%; width:46%">
    <label class="time start-time-first">01:00</label>
    <label class="time end-time-first">12:00</label>
  </li>
  <li class="time-interval" style="left:58%; width:17%">
    <label class="time start-time-second">14:00</label>
    <label class="time end-time-second">18:00</label>
  </li>

будет выглядеть так -> решение

2 голосов
/ 17 марта 2020

Вот рабочий фрагмент с CSS, а также я включаю codepen , в основном вам просто нужно использовать левый и правый атрибут CSS, чтобы это работало после использования position:absolute, для времени окончания я добавляю right:0, чтобы принудительно установить его положение вправо, и left:0 для времени начала, чтобы принудительно устанавливать его положение влево, также для атрибутов top и bottom CSS для положения оси x.

* {
  box-sizing: border-box;
}

ul.day-timeline {
  padding: 0;
  border-left: 1px solid black;
  border-right: 1px solid black;
  height: 20px;
  position: relative;
}
ul.day-timeline:after {
  content: '';
  width: 100%;
  height: 1px;
  background: black;
  display: block;
  position: relative;
  top: 10px;
}
ul.day-timeline li {
  display: block;
  position: absolute;
  background-color: #bed4a7;
  border: 1px solid green;
  z-index: 1;
  padding-left: 5px;
  border-radius: 3px;
  height: 100%;
  font-weight: bold;
  width: 100%;
}
ul.day-timeline li.closed {
  background-color: lightgray;
  border: 1px solid black;
}
ul.day-timeline li.closed label {
  color: black;
}
ul.day-timeline li label {
  font-size: 0.75rem;
  color: green;
}
ul.day-timeline li label.start-time-first {
  position: absolute;
  top: -15px;
  left: 0px;
}
ul.day-timeline li label.end-time-first {
  position: absolute;
  top: 20px;
  right: 0;
}
ul.day-timeline li label.start-time-second {
  position: absolute;
  top: -15px;
  left: 0px;
}
ul.day-timeline li label.end-time-second {
  position: absolute;
  top: 20px;
  right: 0;
}

ul.day-timeline-closed {
  border: none;
}
<ul class="day-timeline">
  <li class="time-interval" style="left:4%; width:46%">
    <label class="time start-time-first">01:00</label>
    <label class="time end-time-first">12:00</label>
  </li>
  <li class="time-interval" style="left:58%; width:17%">
    <label class="time start-time-second">14:00</label>
    <label class="time end-time-second">18:00</label>
  </li>
</ul>




<ul class="day-timeline day-timeline-closed">
  <li class="time-interval closed">
    <label class="time">Closed</label>
  </li>
</ul>
0 голосов
/ 17 марта 2020

Вы успешно перемещаете время начала, но у вас установлено overflow: hidden на ul, поэтому оно скрыто по запросу. Установите ul.day-timeline { overflow: visible; } и go оттуда

...