찾다
웹 프론트엔드CSS 튜토리얼CSS 팁: 플로트 지우기

CSS 팁: 플로트 지우기

Jun 28, 2017 am 10:35 AM
css

CSSclear float이란 무엇인가요?

IE가 아닌 브라우저(예: Firefox)에서 컨테이너 높이가 자동이고 컨테이너 콘텐츠에 부동(플로트는 왼쪽 또는 오른쪽) 요소가 있는 경우, 이 경우 높이 컨테이너의 내용 높이에 맞게 자동으로 늘어날 수 없으므로 내용이 컨테이너 외부로 오버플로되어 레이아웃에 영향을 주거나 심지어 파괴할 수도 있습니다. 이러한 현상을 float Overflow라고 하며, 이러한 현상을 방지하기 위해 수행하는 CSS 처리를 CSS Clear Float라고 합니다.

W3C 예를 인용하면 뉴스 컨테이너는 부동 요소를 둘러싸지 않습니다.


.news {
  background-color: gray;
  border: solid 1px black;
  }

.news img {
  float: left;
  }

.news p {
  float: right;
  }<p><img  src="/static/imghwm/default1.png" data-src="news-pic.jpg" class="lazy" alt="CSS 팁: 플로트 지우기" ></p><p>some text</p>

Clear float 메소드

방법 1: 클리어 속성이 있는 빈 요소 사용

를 지우고 CSS에서 .clear{clear:both;} 속성을 할당하여 부동 소수점을 지웁니다. 청소를 위해
또는
를 사용할 수도 있습니다.


.news {
  background-color: gray;
  border: solid 1px black;
  }

.news img {
  float: left;
  }

.news p {
  float: right;
  }

.clear {
  clear: both;
  }<p><img  src="/static/imghwm/default1.png" data-src="news-pic.jpg" class="lazy" alt="CSS 팁: 플로트 지우기" ></p><p>some text</p><p></p>
장점: 간단하고 코드가 적으며 브라우저 호환성이 좋습니다.

단점: 의미 없는

html 요소를 많이 추가해야 하고, 코드가 충분히 우아하지 않으며 나중에 유지 관리가 쉽지 않습니다.

방법 2: CSS 오버플로 속성

을 사용하여 부동 요소의 컨테이너에 Overflow:hidden; 또는 Overflow:auto;를 추가하여 IE6에서 hasLayout을 트리거해야 합니다. 예를 들어 상위 요소에 대한 컨테이너를 설정하거나 확대/축소:1을 설정합니다.

오버플로 속성을 추가한 후 플로팅 요소가 컨테이너 레이어로 돌아와 컨테이너의 높이를 높여 플로팅 요소를 정리하는 효과를 얻습니다.


 some text

방법 3: 플로팅 요소의 컨테이너에 플로트 추가

또한 플로팅 요소의 컨테이너에

float 속성을 추가하여 내부 플로트를 지웁니다. 전체적으로 플로팅되어 레이아웃에 영향을 미치므로 권장되지 않습니다.

방법 4: 인접 요소 처리 사용

아무 것도 하지 않고 플로팅 요소 뒤의 요소에 Clear 속성을 추가합니다.


.news {
  background-color: gray;
  border: solid 1px black;
  }

.news img {
  float: left;
  }

.news p {
  float: right;
  }

.content{
  clear:both;
  }<p><img  src="/static/imghwm/default1.png" data-src="news-pic.jpg" class="lazy" alt="CSS 팁: 플로트 지우기" ></p><p>some text</p><p></p>

방법 5: CSS :after pseudo-element

를 :after pseudo-element와 결합하여 사용합니다(이것은 의사 클래스가 아니라 가장 가까운 요소를 나타내는 의사 요소라는 점에 유의하세요) 요소 뒤에) 및 IEhack은 현재의 모든 주요 주류 브라우저와 완벽하게 호환됩니다. 여기서 IEhack은 hasLayout 트리거를 의미합니다.

플로팅 요소의 컨테이너에 클리어픽스 클래스를 추가한 다음 이 클래스에 :after 의사 요소를 추가하여 요소 끝에 보이지 않는 블록 요소(블록 요소)를 추가하여 플로트를 정리합니다.


.news {
  background-color: gray;
  border: solid 1px black;
  }

.news img {
  float: left;
  }

.news p {
  float: right;
  }

.clearfix:after{
  content: "020"; 
  display: block; 
  height: 0; 
  clear: both; 
  visibility: hidden;  
  }

.clearfix {
  /* 触发 hasLayout */ 
  zoom: 1; 
  }<p><img  src="/static/imghwm/default1.png" data-src="news-pic.jpg" class="lazy" alt="CSS 팁: 플로트 지우기" ></p><p>some text</p>
CSS 의사 요소를 통해 컨테이너 내부 요소 끝에 보이지 않는 공백 "020" 또는 점 "."을 추가하고 클리어 속성을 할당하여 플로트를 지웁니다. IE6 및 IE7 브라우저의 경우 haslayout을 트리거하려면clearfix 클래스에 Zoom:1을 추가해야 합니다.

요약

위의 예를 통해 float를 지우는 방법은 두 가지 범주로 나눌 수 있음을 쉽게 알 수 있습니다.

하나는 Clear 속성을 추가하는 것을 포함하여 Clear 속성을 사용하는 것입니다: Both 속성 부동 요소의 끝에서 빈 p는 요소를 닫는 데 사용됩니다. 실제로 :after 의사 요소를 사용하는 방법은 점의 내용과 클리어: 두 속성을 모두 추가하여 달성됩니다. 요소의 끝.

두 번째는 플로팅 요소의 상위 요소인 BFC(Block Formatting Contexts, 블록 수준 포맷팅 컨텍스트)를 트리거하여 상위 요소가 플로팅 요소를 포함할 수 있도록 하는 것입니다.

추천

웹페이지의 기본 레이아웃에서 :after 의사 요소 메서드를 사용하고 이를 부동 소수점 정리를 위한 주요 방법으로 사용합니다. ul과 같은 작은 모듈에서는 Overflow:hidden을 사용합니다. 숨겨진 오버플로 요소 문제에 주의하세요) ; 플로팅 요소인 경우 특별한 처리 없이 내부 플로트를 자동으로 지울 수 있습니다. 이전 플로트를 지우려면 본문의 인접한 요소를 사용하세요.

마지막으로 비교적 완벽한 :after 의사 요소 방법을 사용하여 부동 소수점을 정리하여 문서 구조를 더 명확하게 만들 수 있습니다.

위 내용은 CSS 팁: 플로트 지우기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
@keyframes 및 @Media와 같이 @Rules는 얼마나 많은 특이성을 가지고 있습니까?@keyframes 및 @Media와 같이 @Rules는 얼마나 많은 특이성을 가지고 있습니까?Apr 18, 2025 am 11:34 AM

나는 다른 날이 질문을 받았다. 나의 첫 번째 생각은 : 이상한 질문입니다! 특이성은 선택기에 관한 것이며 At-Rules는 선택기가 아니므로 ... 무의미합니까?

@Media 및 @Support 쿼리를 중첩 할 수 있습니까?@Media 및 @Support 쿼리를 중첩 할 수 있습니까?Apr 18, 2025 am 11:32 AM

그렇습니다. 당신은 할 수 있습니다. 그리고 그것은 실제로 어떤 순서로 중요하지 않습니다. CSS 전 처리기가 필요하지 않습니다. 일반 CSS에서 작동합니다.

빠른 Gulp 캐시 파열빠른 Gulp 캐시 파열Apr 18, 2025 am 11:23 AM

CSS 및 JavaScript (및 이미지 및 글꼴 등)와 같은 자산에 멀리 떨어진 캐시 헤더를 설정해야합니다. 브라우저를 알려줍니다

CSS의 품질과 복잡성을 모니터링하는 스택을 찾아CSS의 품질과 복잡성을 모니터링하는 스택을 찾아Apr 18, 2025 am 11:22 AM

많은 개발자들은 CSS 코드베이스를 유지하는 방법에 대해 글을 썼지 만 코드베이스의 품질을 어떻게 측정하는지에 대해 많은 글을 쓰지 않습니다. 물론, 우리는 가지고 있습니다

Datalist는 가치를 시행하지 않고 값을 제안하는 것입니다Datalist는 가치를 시행하지 않고 값을 제안하는 것입니다Apr 18, 2025 am 11:08 AM

짧고 임의의 텍스트를 수락 해야하는 양식이 있습니까? 이름이나 다른 것 같습니다. 정확히 무엇을위한 것입니다. 많은 것이 있습니다

취리히에서 열린 전면 회의취리히에서 열린 전면 회의Apr 18, 2025 am 11:03 AM

나는 프론트 컨퍼런스를 위해 스위스 취리히로 향하게되어 매우 기쁩니다 (그 이름과 URL을 사랑합니다!). 나는 전에 스위스에 가본 적이 없기 때문에 나는 흥분했다

CloudFlare Workers와 함께 풀 스택 서버리스 애플리케이션 구축CloudFlare Workers와 함께 풀 스택 서버리스 애플리케이션 구축Apr 18, 2025 am 10:58 AM

소프트웨어 개발에서 제가 가장 좋아하는 개발 중 하나는 서버리스의 출현이었습니다. 세부 사항에 푹 빠지는 경향이있는 개발자로서

NUXT 응용 프로그램에서 동적 경로 생성NUXT 응용 프로그램에서 동적 경로 생성Apr 18, 2025 am 10:53 AM

이 게시물에서는 들어오는 데이터를 위해 동적 경로를 만드는 방법을 보여주기 위해 NetLify에 구축하고 배포 한 전자 상거래 상점 데모를 사용합니다. 상당히입니다

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SecList

SecList

SecLists는 최고의 보안 테스터의 동반자입니다. 보안 평가 시 자주 사용되는 다양한 유형의 목록을 한 곳에 모아 놓은 것입니다. SecLists는 보안 테스터에게 필요할 수 있는 모든 목록을 편리하게 제공하여 보안 테스트를 더욱 효율적이고 생산적으로 만드는 데 도움이 됩니다. 목록 유형에는 사용자 이름, 비밀번호, URL, 퍼징 페이로드, 민감한 데이터 패턴, 웹 셸 등이 포함됩니다. 테스터는 이 저장소를 새로운 테스트 시스템으로 간단히 가져올 수 있으며 필요한 모든 유형의 목록에 액세스할 수 있습니다.

PhpStorm 맥 버전

PhpStorm 맥 버전

최신(2018.2.1) 전문 PHP 통합 개발 도구

Atom Editor Mac 버전 다운로드

Atom Editor Mac 버전 다운로드

가장 인기 있는 오픈 소스 편집기

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경