Как правильно сверстать модальное окно?

413
09 сентября 2018, 15:30

Написал тестовое модальное окно, но возникла проблема.

Допустим, произошло какое-то событие (например клик) и появилось модальное окно, параметры этого окна:

  1. Запрещено скролить основной контент страницы - сделал.
  2. Фон модального окна (черный-прозрачный) на всю видимую область окна браузера - сделал.
  3. Модальное окно по центру - сделал.
  4. Скролл модального окна, если его высота выходит за пределы окна браузера - сделал.

Вопросы:

  1. При увеличение содержимого (или высоты) модального окна, верхняя часть модального окна оказывается за областью видимости, как быть?
  2. Как Вы реализовали бы подобную задачу с модальным окном? Буду благодарен за любые замечания!

* { 
  box-sizing: border-box; 
} 
 
html, body { 
  margin: 0; 
  padding: 0; 
  width: 100%; 
  height: 100%; 
  position: fixed; 
} 
 
.modal-container { 
  position: absolute; 
  top: 0; 
  left: 0; 
  background: rgba(0, 0, 0, 0.5); 
  width: 100%; 
  height: 100%; 
  display: flex; 
  align-items: center; 
  justify-content: center; 
  overflow: auto; 
} 
 
.modal { 
  position: relative; 
  background: chocolate; 
  padding: 20px; 
  flex: 0 0 50%; 
  max-width: 50%; 
  margin-top: 50px; 
  margin-bottom: 50px; 
  overflow: auto; 
  /*height: 1000px;*/ /*имитируем высоту модального окна в 1000px*/ 
} 
 
.content { 
  background: antiquewhite; 
  padding-left: 20px; 
  padding-right: 20px; 
}
<div class="modal-container"> 
  <div class="modal"> 
    Maecenas nec odio et 
    antetincidunt tempus. Donec 
    vitae sapien ut libero 
    venenatis faucibus. Nullam quis 
    ante. 
  </div> 
</div> 
 
<div class="content"> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
  <p> 
    Maecenas nec odio et ante tincidunt 
    tempus. Donec vitae sapien ut libero 
    venenatis faucibus. Nullam quis ante. 
    Etiam sit amet orci eget eros 
    faucibus tincidunt. Duis leo. Sed 
    fringilla mauris sit amet nibh. Donec 
    sodales sagittis magna. Sed 
    consequat, leo eget bibendum sodales, 
    augue velit cursus nunc, 
  </p> 
</div>

Answer 1

Ознакомьтесь: https://getbootstrap.com/docs/4.0/components/modal/

Чтобы не вылазило за область видимости нужно поставить max-height(максимальная высота) или для родительского блока height: auto

READ ALSO
Что такое top-level position в HTML?

Что такое top-level position в HTML?

В документации Bootstrap 41 в разделе Modal непонятное обозначение HTML top-level positions ссылка

230
Программы для верстки! [закрыт]

Программы для верстки! [закрыт]

Я увлекся веб версткой сайтов из psd шаблоновХочу спросить какие приложения помогут мне в этом

268
Содержит ли normal elements - custom elements?

Содержит ли normal elements - custom elements?

Входит ли custom elements в группу normal elements?

255
Строчные элементы во flexbox&#39;ах

Строчные элементы во flexbox'ах

Возможно странный вопрос но почему строчным элементам воженным в блок с display:flex можно задавать размеры?

274