Текст в родителе флоатов в CSS

Давайте уберем свойство height для дива и поставим небольшой текст перед картинкой.

В этом случае высота нашего дива будет равна высоте текста, а картинка по-прежнему вылезет за див:

<div> text <img src="img.png" alt=""> </div> div { border: 1px solid red; } img { float: right; }

:

Давайте поставим текст после картинки - результат не изменится:

<div> <img src="img.png" alt=""> text </div> div { border: 1px solid red; } img { float: right; }

:

Давайте сделаем так, чтобы картинка плавала по левому краю - результат будет аналогичным:

<div> <img src="img.png" alt=""> text </div> div { border: 1px solid red; } img { float: left; }

:

Давайте снизу добавим еще один див - картинка налезет и на него:

<div> <img src="img.png" alt=""> text </div> <div> text </div> div { border: 1px solid red; } img { float: left; }

:

Если же в первый див добавить настолько много текста, что по высоте он будет больше картинки - она не будет налезать на второй див:

<div> <img src="img.png" alt=""> long text... </div> <div> text </div> div { text-align: justify; border: 1px solid red; } img { float: left; }

:

Этот момент очень важен - при разработке может быть такое, что в каком-то блоке у вас достаточно много текста, а затем при реальной работе сайта в этом блоке будет меньше текста, чем запланировано. Получится, что в этом случае проявится проблема с налезанием плавающих элементов на соседние блоки.



Чат с GPT Компилятор