많은 사람들이 이 질문을 한다고 생각합니다. 페이지 레이아웃, 부동 또는 위치:절대 중 어느 것을 사용하는 것이 더 낫습니까? 레이아웃이기 때문에 float를 사용하는 것이 더 좋습니다. 이 플로트는 지워질 수 있으며 일반적으로 전체 레이아웃에 영향을 미치지 않습니다. 위치, 위치 지정은 제한되지 않습니다. 이는 레이아웃이 아닌 것으로 보입니다. 일반적으로 특수한 위치 지정이나 레이어 플로팅을 수행할 때 사용하는 것을 고려해 볼 수 있습니다. 일반적인 페이지 레이아웃의 경우 FLOAT
1.float 속성을 사용하여 요소가 부동하는 방향을 정의하는 것이 좋습니다. 역사적으로 이 속성은 항상 이미지에 적용되어 텍스트가 이미지 주위를 둘러싸도록 했지만 CSS에서는 모든 요소가 부동될 수 있습니다. 부동 요소는 요소 유형에 관계없이 블록 수준 상자를 만듭니다. p는 그 자체로 한 줄을 차지하는 전형적인 블록 수준의 요소이다.
먼저 가장 기본적인 블록레벨 요소들이 어떻게 배열되어 있는지 살펴보겠습니다. html 코드에서 다음 스타일은 이를 기반으로 합니다.
코드 복사 코드는 다음과 같습니다
class="box2 >
css 코드:
코드 복사
코드는 다음과 같습니다.
.boxBg{
여백: 0 자동;
높이:200px;
테두리:2px 솔리드 #ccc} .box1{ 너비:100px;
높이:50px; 배경 색상: 빨간색
}
.box2{
너비:100px;
높이:50px;
배경색: 파란색
}
.box3{
너비:100px;
높이:50px;
배경색: 녹색
}
실행 결과:
p는 블록 수준 요소이므로 상자가 수직으로 배열됩니다. 실제 작업에서는 프레임을 수평으로 배열해야 하는 경우가 많습니다. 이를 수행하는 방법에는 두 가지가 있습니다. 첫 번째 항목은 다음과 같이 표시됩니다:inlin-block;
코드 복사
.boxBg{ margin: 0 auto;
height:200px;
border:2px solid #ccc} .box1{ 너비:100px;
높이:50px; 배경색: 빨간색;
디스플레이:inline-block
}
.box2{
너비:100px;
높이:50px;
배경- 색상:파란색;
디스플레이:inline-block
디스플레이:인라인 -차단 .box3{ 너비: 100px; 디스플레이: 인라인 블록
중간에 공백이 생기는 근본적인 이유는 요소 사이의 공백에서 비롯됩니다. , 따라서 상위 요소에 fone-size 크기를 설정하면 공백의 크기를 조정할 수 있습니다.
코드 복사
코드는 다음과 같습니다:
.boxBg{
margin: 0 auto;
width:500px;
height:200px;
border:2px solid #ccc;
글꼴 크기:34px;
}
글꼴 크기:34px를 변경하면 간격이 더 넓어집니다.
실행 결과:
마찬가지로 공백을 제거하려면 코드를 복사해야 합니다.
.boxBg{
margin: 0 auto;
width:500px;
height:200px;
border:2px solid #ccc;
font-size:0
}
실행 결과:
너무 편리합니다 원하는 레이아웃을 얻은 후에는 상자 안의 텍스트도 사라졌으며 이는 텍스트의 크기가 간격에 영향을 미친다는 것도 증명합니다. 하위 요소에서 재설정하면 됩니다. 물론 오늘의 초점은 그게 아니다. 동일한 효과 float:left도 쉽게 얻을 수 있습니다. }
.box1{너비:100px; 높이:50px; 배경색: 빨간색;
부동:왼쪽 }
.box2{
너비:100px;
높이:50px;
배경색: 파란색;
float:left
}
.box3{
width:100px;
height:50px;
background-color:green;
float:left
}
실행 결과:
요소 부동 소수점을 추가한 후 부동 요소는 상위 요소의 테두리 또는 다른 부동 요소의 테두리에 닿은 직후에 표시됩니다. 예를 들어 다음 예에서는 부동 요소의 전체 너비가 상위 요소보다 크면 줄이 줄바꿈됩니다. 줄이 줄바꿈되면 이전 부동 소수점이 발견되어 그 뒤에 표시됩니다.
코드를 복사하세요.
코드는 다음과 같습니다:
실행 결과 :
box3의 float: left를 제거하면 결과는 어떻게 되나요? 이해에 따르면 부동 요소는 공간을 차지하지 않습니다. 즉, 프레임 3은 프레임 1을 무시하고 프레임 2는 상위 요소의 테두리 바로 옆에 표시됩니다. 즉, 프레임 1이 프레임 3을 덮습니다. 결과?
코드를 복사하세요 코드는 다음과 같습니다:
.box3{
width:100px;
height:50px;
background-color:green;
}
실행 결과:
이유 상자 3 텍스트 상자 1에 포함되지 않고 아래에 표시됩니까? 그럼 코드를 보세요, 사진을 보세요
코드를 복사하세요 코드는 다음과 같습니다:
.box3{
height:50px;
background-color:green;
}
실행 결과:
차이가 보이시죠? 없어졌나요? 예. box3은 너비를 정의하지 않습니다. 너비를 정의하지 않으면 기본 너비는 상위 요소의 너비가 됩니다. 즉, 이 때 부동 요소는 부동 요소가 아닌 요소를 덮습니다. , 상자 3 앞의 200px 너비가 플로팅 요소로 채워져 있습니다. 왜 텍스트가 덮여 있지 않고 텍스트가 플로팅 요소 뒤에 200px로 압착되어 있습니까?
플로팅 요소는 블록의 공간을 차지하지 않으므로 상자 3은 상위 컨테이너 너비 500px의 100%이지만 플로팅 요소는 다른 공간, 즉 일반 용어로는 공간을 차지합니다. 텍스트가 차지했습니다.
이것이 플로트된 후 텍스트가 이미지 주위를 자동으로 감싸는 이유이기도 합니다. 플로팅 요소는 블록 수준 공간을 차지하지 않지만 블록 수준 요소 내의 텍스트 및 인라인 요소에 영향을 미칩니다.
이 경우 세 상자의 너비를 동일하게 하려면 상자 3의 너비:300px;
코드는 다음과 같습니다.
.box3{
너비 :300px;
height:50px;
background -color:green;
}
실행 결과:
코드를 복사해야 합니다. 코드는 다음과 같습니다.
.box3{
float:left;
width:100px;
height:50px;
background-color:green;
clear:left
실행 결과:
이해했습니다. 다음은 합시다! 배경과 프레임의 높이를 동일하게 만드는 방법에 대해 이야기합니다. 첫 번째 방법: 가장 직접적인 방법은 배경 높이를 프레임과 동일하게 설정하는 것입니다. 물론 이것이 핵심은 아닙니다. 플로트. 먼저 예제를 살펴보겠습니다.
코드는 다음과 같습니다.
> red;
}
.box2{
float:left;
너비:100p x;
높이: 50px;
background-color:blue;
}
.box3{
float:left;
너비:100px;
높이: 50px;
배경색:녹색;
}
.clear{
너비:1 00px;
높이:50px;
}
;
, ~
실행 결과:
위의 결과는 바로 추가된 것이 분명합니다. 동일한 높이의 빈 요소입니다. 이 요소는 플로팅되지 않으므로 배경과 동일하므로 배경이 늘어납니다. 사실 클리어 플로트를 사용하는 원리는 이와 같고, 배경도 열어보려고 합니다. 위의 클리어의 너비와 높이를 제거하고 클리어 속성을 추가합니다
코드를 복사하세요
코드는 다음과 같습니다. 다음:
.clear{
지우기: 왼쪽;
}
실행 결과:
아직 명확하지 않을 수 있습니다. 지우기 상자에 몇 단어를 추가해 보세요실행 결과:
clear는clear:left를 사용하기 때문에 요약하자면 앞서 언급한 것처럼 Clear의 왼쪽에는 부동 요소가 있을 수 없으므로 새 줄에 표시해야 합니다. 이런 식으로 사진의 결과가 실제로는 하나의 요소에 의해 배경이 떠받치고 있다는 것을 알 수 있습니다. 물론, 이를 달성하는 다른 방법도 있습니다. 여기서 가장 중요한 것은 플로팅을 명확하게 설명하는 것입니다. :)
위 내용은 CSS 부동 속성과 위치 비교:절대의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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

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

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

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

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

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

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

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


핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

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

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

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기

ZendStudio 13.5.1 맥
강력한 PHP 통합 개발 환경
