CSS의 요소는 기본적으로 일반적인 흐름에 따라 배열됩니다. 요소 배열을 변경할 수 있는 방법은 두 가지가 있는데, 다른 방법은 이전 글에서 자세히 설명했습니다. 이제 설명할 위치 지정 속성에는 정적, 상대, 절대 및 고정의 네 가지 값이 있으며 기본적으로 0인 왼쪽 및 위쪽 속성을 통해 위치 지정 요소의 위치를 제어합니다. 다음 내용에서는 4가지 속성값의 사용법과 차이점을 설명하겠습니다.
Static은 위치 속성의 기본값입니다. 위치 지정이 없고 요소가 일반 흐름으로 나타남을 나타냅니다.
상대적으로 위치가 지정된 요소를 생성하고 정상 위치를 기준으로 위치를 지정합니다.
다음 사례를 살펴보세요.
HTML 코드:
<p class="father"> <p class="son">son</p></p>
CSS 코드:
.father{ width: 500px; height: 500px; background: pink; margin: 0 auto; }.son{ width: 200px; height: 200px; background: lavender; margin: 0 auto; }
효과는 다음과 같습니다:
코드 설명: 일반적인 상황에서는 클래스 이름이 son인 p가 다음과 같이 나타납니다. 영역에서 요소에 상대 위치 추가:
CSS 코드:
.son{ width: 200px; height: 200px; background: lavender; margin: 0 auto; position: relative; left: 0; top: 0; }
효과는 다음과 같습니다.
상대 위치 지정을 추가한 후에도 위의 경우가 변경되지 않은 것을 확인할 수 있습니다. 그 이유는 상대 위치가 자신의 위치를 기준으로 위치 지정되어 문서 흐름에서 벗어나지 않기 때문입니다. 실제로 요소가 상대 위치 지정으로 설정되고 left:0;top:0;을 제공한 후에는 요소에 아무런 영향을 미치지 않습니다. 왼쪽 값과 위쪽 값이 0이 아닌 경우 어떻게 되는지 계속 살펴보겠습니다.
CSS 코드:
.son{ width: 200px; height: 200px; background: lavender; margin: 0 auto; position: relative; left: 50px; top: 20px; }
효과는 다음과 같습니다. 다음과 같습니다:
효과 설명:
빨간색 선 프레임은 요소 자체가 있어야 하는 위치입니다. 왼쪽 속성이 50px이고 맨 위 속성이기 때문입니다. 20px이면 요소 자체가 존재해야 할 위치(즉, 빨간색 선 프레임의 위치)를 그림과 같이 왼쪽으로 50px, 위쪽으로 20px만큼 상대적으로 Offset하게 됩니다.
첫째, 절대 위치 지정 요소는 문서 흐름에서 벗어나게 됩니다. 둘째, 절대 위치 지정 요소가 어떻게 위치 지정되는지 분석해 보겠습니다. 절대 위치에 있는 요소는 먼저 가장 가까운 위치에 있는 상위 요소를 찾습니다(정적 제외). 위치에 있는 상위 요소가 없으면 루트 요소 html이 없을 때까지 위쪽으로 계속 검색합니다. 위치가 지정된 상위 레벨 요소는 html을 기준으로 위치가 지정됩니다.
다음 사례를 살펴보겠습니다.
HTML 코드:
<p class="father"> <p class="son1">son1</p> <p class="son2">son2</p></p>
CSS 코드:
.father{ width: 500px; height: 500px; background: pink; margin: 0 auto; } .son1{ width: 150px; height: 150px; background: lavender; margin: 0 20px; position: absolute; left: 0px; top: 0px; } .son2{ width: 150px; height: 150px; background: skyblue; margin: 0 20px; position: absolute; left: 0px; top: 0px; }
표시된 효과:
효과 분석:
절대적으로 배치된 요소는 문서에서 분리됩니다. 흐름 및 위치 지정은 이전 위치 지정을 포함하므로 son2는 son1을 포함합니다. son1 및 son2에는 위치 지정 상위 요소가 없으므로 루트 요소 html을 기준으로 위치가 지정됩니다. 위치 지정 요소가 있으면 어떻게 되나요?
CSS 코드:
.father{ position: relative; width: 500px; height: 500px; background: pink; margin: 0 auto; }.son1{ width: 150px; height: 150px; background: lavender; margin: 0 20px; position: absolute; left: 0px; top: 0px; }.son2{ width: 150px; height: 150px; background: skyblue; margin: 0 20px; position: absolute; left: 50px; top: 50px; }
효과는 다음과 같습니다.
효과 분석:
Father는 son1과 son2의 위치 지정 부모이므로 son1과 son2는 father보다 상대적으로 위치 지정됩니다. son2는 son1보다 위에 있습니다. 상대 위치 지정의 특성으로 인해 상대 위치 지정은 절대 위치 지정을 위한 포함 상자로 사용되는 경우가 많습니다.
페이지 오른쪽 하단에 있는 맨 위로 돌아가기 버튼과 같이 페이지에서 고정 위치 지정이 필요한 경우가 많습니다. . 고정 위치란 브라우저 창의 크기에 따라 요소가 항상 이 위치에 고정된다는 의미입니다. 페이지가 슬라이드되더라도 위치는 영향을 받지 않습니다. 다음 사례를 살펴보겠습니다.
HTML 코드:
<body> <p class="backTop">top</p></body>
CSS 코드:
body{ height: 2000px; background: #C0C0C0; }.backTop{ width: 70px; height: 70px; background: pink; }
위치 지정이 없는 페이지의 효과는 다음과 같습니다.
다음과 같이 버튼에 고정 위치를 지정합니다.
CSS 코드:
.backTop{ width: 70px; height: 70px; background: pink; position: fixed; right: 30px; bottom: 30px; }
효과는 다음과 같습니다.
페이지가 스크롤되더라도 버튼의 위치는 변하지 않습니다. 페이지에 광고 영역이 많이 있습니다. 페이지가 스크롤되더라도 광고의 위치는 항상 고정되어 있습니다. 고정된 위치의 요소도 문서 흐름 외부에 있다는 점에 유의하세요.
여러 가지 부동 사례에 대해 두 가지 측면에서만 고려하면 한편으로는 위치를 지정하는 방법의 문제입니다. 반면에 위치 지정 요소가 문서 흐름에서 분리되는지 여부에 대한 문제가 있습니다(문서 흐름에서 분리되는 문제는 여기에서 자세히 설명하지 않습니다). 이 두 가지 측면을 철저히 이해하면 포지셔닝을 쉽게 이해할 수 있습니다. 여러 유형의 포지셔닝을 요약해 보겠습니다.
위치: 정적(정적 위치 지정) 고정(고정 위치 지정) 상대 (상대 위치 지정) 절대 (절대 위치 지정)
static:position의 기본값은 위치 지정이 없는 것과 같습니다. 문서 흐름에서 벗어나지 않으며 페이지 공간을 차지합니다.
relative: 위치는 그 자체에 상대적입니다. 문서 흐름에서 벗어나지 않으며 페이지 공간을 차지합니다.
절대: 위치는 위치가 지정된 상위 요소를 기준으로 합니다. 문서 흐름과 분리되어 페이지 공간을 차지하지 않습니다.
고정: 위치는 브라우저 창을 기준으로 합니다. 문서 흐름과 분리되어 페이지 공간을 차지하지 않습니다.
CSS에서의 위치 지정에 대한 자세한 내용은 PHP 중국어 웹사이트의 관련 기사를 참고하세요!