При разработке страницы столкнулся со следующей ситуацией:
Родительский контейнер не устанавливает стиль высоты контента, а дочерние элементы в контейнере устанавливают плавающий стиль, который выходит за рамки стандартного потока. Высота по умолчанию будет установлена на 0 пикселей, что приведет к различного рода хаосу при отображении;
Чтобы справиться с вышеуказанной ситуацией, вы можете использовать операцию «очистить плавающее число»;
прозрачный поплавок Основная функция : решать Модель родительского контейнера потому что дочерний элемент установлено на плавающий элемент привести к Высота по умолчанию равна 0 Пиксель вопрос ;
прозрачный поплавок Эффект : отец-контейнер При определении высоты ,рассмотрю 浮动дочерний элемент высота,Воляплавающий элементвысота вычислитьсуществоватьотец-контейнериз Общая высота ;
прозрачный поплавокграмматика :
CSS селектор {
clear: значение атрибута;
}
Значение атрибута:
Обычно при использовании , использовать только clear: both;
стиль ;
Рекомендуется " дополнительный метод маркировки " ,существоватьпоследнийплавающий элементизконец, добавить дополнительный тег , следующее :
<div class="clear"></div>
Вы также можете использовать другие теги, например:
<br class="clear"/>
В коде ниже , отец-контейнер 1 Высота не указана , Есть две внутренние настройки. плавающий элемент , Не указан стандартный элемент потока , Итак, по умолчанию , Его высота составляет 0 ;
отец-контейнер 1 из братские элементы , отображается непосредственно в отец-контейнер 1 из Сделать ставку , отец-контейнер 1 Можно рисовать только границы , Высота размера контента 0 , под двумя границами , то есть отец-контейнер 2 из коробки ;
Пример кода проблемы:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>плавать ясно - дополнительный метод маркировки</title>
<style>
/* Очистите внутренние и внешние поля метки по умолчанию. */
* {
padding: 0;
margin: 0;
}
/* Очистить список, стиль по умолчанию ( В основном передняя часть ) */
li {
list-style: none;
}
/* Установить общий фон */
body {
background-color: #f4f4f4;
}
/* Адаптивная вставка изображения */
img {
width: 100%;
}
/* Ниже приводится официальный контент */
/* отец-контейнер 1 Высота не указана , по умолчанию 0 Пиксель */
.father1 {
width: 500px;
background-color: pink;
border: 2px solid green;
}
/* дочерний элемент 1 */
.son1 {
float: left;
width: 200px;
height: 200px;
background-color: blue;
}
/* дочерний элемент 2 */
.son2 {
float: left;
width: 250px;
height: 250px;
background-color: red;
}
/* отец-контейнер 2 - отец-контейнер 1 избратские элементы */
.father2 {
width: 700px;
height: 150px;
background-color: purple;
}
</style>
</head>
<body>
<div class="father1">
<div class="son1"></div>
<div class="son2"></div>
</div>
<div class="father2"></div>
</body>
</html>
выставка Эффект :
существовать отец-контейнер 1 father1 из Последний дочерний элемент son2 позже , Добавить новый из дочерний элемент , для этогодочерний элементнастраивать clear: both;
стиль атрибута , будет автоматически son1 и son2 Измеряется как стандартный элемент потока , в это время отец-контейнер 1 будет высота ;
дополнительный метод пример кода маркировки :
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>плавать ясно - дополнительный метод маркировки</title>
<style>
/* Очистите внутренние и внешние поля метки по умолчанию. */
* {
padding: 0;
margin: 0;
}
/* Очистить список, стиль по умолчанию ( В основном передняя часть ) */
li {
list-style: none;
}
/* Установить общий фон */
body {
background-color: #f4f4f4;
}
/* Адаптивная вставка изображения */
img {
width: 100%;
}
/* Ниже приводится официальный контент */
/* отец-контейнер 1 Высота не указана , по умолчанию 0 Пиксель */
.father1 {
width: 500px;
background-color: pink;
border: 2px solid green;
}
/* дочерний элемент 1 */
.son1 {
float: left;
width: 200px;
height: 200px;
background-color: blue;
}
/* дочерний элемент 2 */
.son2 {
float: left;
width: 250px;
height: 250px;
background-color: red;
}
/* отец-контейнер 2 - отец-контейнер 1 избратские элементы */
.father2 {
width: 700px;
height: 150px;
background-color: purple;
}
/* прозрачный поплавок */
.son3 {
clear: both;
}
</style>
</head>
<body>
<div class="father1">
<div class="son1"></div>
<div class="son2"></div>
<div class="son3"></div>
</div>
<div class="father2"></div>
</body>
</html>
выставка Эффект :