찾다
웹 프론트엔드CSS 튜토리얼CSS에서의 위치 지정에 대해 자세히 논의

CSS의 요소는 기본적으로 일반적인 흐름에 따라 배열됩니다. 요소 배열을 변경할 수 있는 방법은 두 가지가 있는데, 다른 방법은 이전 글에서 자세히 설명했습니다. 이제 설명할 위치 지정 속성에는 정적, 상대, 절대 및 고정의 네 가지 값이 있으며 기본적으로 0인 왼쪽 및 위쪽 속성을 통해 위치 지정 요소의 위치를 ​​제어합니다. 다음 내용에서는 4가지 속성값의 사용법과 차이점을 설명하겠습니다.

1. static(정적 위치 지정)

Static은 위치 속성의 기본값입니다. 위치 지정이 없고 요소가 일반 흐름으로 나타남을 나타냅니다.

2. 상대적(상대 위치 지정)

상대적으로 위치가 지정된 요소를 생성하고 정상 위치를 기준으로 위치를 지정합니다.

다음 사례를 살펴보세요.

HTML 코드:

<p>
    </p><p>son</p>

CSS 코드:

.father{
    width: 500px;
    height: 500px;
    background: pink;
    margin: 0 auto;
}.son{
    width: 200px;
    height: 200px;
    background: lavender;
    margin: 0 auto;
}

효과는 다음과 같습니다:

详谈css中的定位

코드 설명: 일반적인 상황에서는 클래스 이름이 son인 p가 다음과 같이 나타납니다. 영역에서 요소에 상대 위치 추가:

CSS 코드:

.son{
    width: 200px;
    height: 200px;
    background: lavender;
    margin: 0 auto;
    position: relative;
    left: 0;
    top: 0;
}

효과는 다음과 같습니다.

详谈css中的定位

상대 위치 지정을 추가한 후에도 위의 경우가 변경되지 않은 것을 확인할 수 있습니다. 그 이유는 상대 위치가 자신의 위치를 ​​기준으로 위치 지정되어 문서 흐름에서 벗어나지 않기 때문입니다. 실제로 요소가 상대 위치 지정으로 설정되고 left:0;top:0;을 제공한 후에는 요소에 아무런 영향을 미치지 않습니다. 왼쪽 값과 위쪽 값이 0이 아닌 경우 어떻게 되는지 계속 살펴보겠습니다.

CSS 코드:

.son{
    width: 200px;
    height: 200px;
    background: lavender;
    margin: 0 auto;
    position: relative;
    left: 50px;
    top: 20px;
}

효과는 다음과 같습니다. 다음과 같습니다:

详谈css中的定位

효과 설명:

빨간색 선 프레임은 요소 자체가 있어야 하는 위치입니다. 왼쪽 속성이 50px이고 맨 위 속성이기 때문입니다. 20px이면 요소 자체가 존재해야 할 위치(즉, 빨간색 선 프레임의 위치)를 그림과 같이 왼쪽으로 50px, 위쪽으로 20px만큼 상대적으로 Offset하게 됩니다.

3. 절대(absolute positioning)

첫째, 절대 위치 지정 요소는 문서 흐름에서 벗어나게 됩니다. 둘째, 절대 위치 지정 요소가 어떻게 위치 지정되는지 분석해 보겠습니다. 절대 위치에 있는 요소는 먼저 가장 가까운 위치에 있는 상위 요소를 찾습니다(정적 제외). 위치에 있는 상위 요소가 없으면 루트 요소 html이 없을 때까지 위쪽으로 계속 검색합니다. 위치가 지정된 상위 레벨 요소는 html을 기준으로 위치가 지정됩니다.

다음 사례를 살펴보겠습니다.

HTML 코드:

<p>
    </p><p>son1</p>
    <p>son2</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;
}

표시된 효과:

详谈css中的定位

효과 분석:

절대적으로 배치된 요소는 문서에서 분리됩니다. 흐름 및 위치 지정은 이전 위치 지정을 포함하므로 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;
}

효과는 다음과 같습니다.

详谈css中的定位

효과 분석:

Father는 son1과 son2의 위치 지정 부모이므로 son1과 son2는 father보다 상대적으로 위치 지정됩니다. son2는 son1보다 위에 있습니다. 상대 위치 지정의 특성으로 인해 상대 위치 지정은 절대 위치 지정을 위한 포함 상자로 사용되는 경우가 많습니다.

4. 고정(고정 위치 지정)

페이지 오른쪽 하단에 있는 맨 위로 돌아가기 버튼과 같이 페이지에서 고정 위치 지정이 필요한 경우가 많습니다. . 고정 위치란 브라우저 창의 크기에 따라 요소가 항상 이 위치에 고정된다는 의미입니다. 페이지가 슬라이드되더라도 위치는 영향을 받지 않습니다. 다음 사례를 살펴보겠습니다.

HTML 코드:

    <p>top</p>

CSS 코드:

body{
    height: 2000px;
    background: #C0C0C0;
}.backTop{
    width: 70px;
    height: 70px;
    background: pink;
}

위치 지정이 없는 페이지의 효과는 다음과 같습니다.

详谈css中的定位

다음과 같이 버튼에 고정 위치를 지정합니다.

CSS 코드:

.backTop{
    width: 70px;
    height: 70px;
    background: pink;
    position: fixed;
    right: 30px;
    bottom: 30px;
}

효과는 다음과 같습니다.

详谈css中的定位

페이지가 스크롤되더라도 버튼의 위치는 변하지 않습니다. 페이지에 광고 영역이 많이 있습니다. 페이지가 스크롤되더라도 광고의 위치는 항상 고정되어 있습니다. 고정된 위치의 요소도 문서 흐름 외부에 있다는 점에 유의하세요.

5. 요약

여러 가지 부동 사례에 대해 두 가지 측면에서만 고려하면 한편으로는 위치를 지정하는 방법의 문제입니다. 반면에 위치 지정 요소가 문서 흐름에서 분리되는지 여부에 대한 문제가 있습니다(문서 흐름에서 분리되는 문제는 여기에서 자세히 설명하지 않습니다). 이 두 가지 측면을 철저히 이해하면 포지셔닝을 쉽게 이해할 수 있습니다. 여러 유형의 포지셔닝을 요약해 보겠습니다.

 

위치: 정적(정적 위치 지정) 고정(고정 위치 지정) 상대 (상대 위치 지정) 절대 (절대 위치 지정)

static:position의 기본값은 위치 지정이 없는 것과 같습니다. 문서 흐름에서 벗어나지 않으며 페이지 공간을 차지합니다.

relative: 위치는 그 자체에 상대적입니다. 문서 흐름에서 벗어나지 않으며 페이지 공간을 차지합니다.

절대: 위치는 위치가 지정된 상위 요소를 기준으로 합니다. 문서 흐름과 분리되어 페이지 공간을 차지하지 않습니다.

고정: 위치는 브라우저 창을 기준으로 합니다. 문서 흐름과 분리되어 페이지 공간을 차지하지 않습니다.

CSS에서의 위치 지정에 대한 자세한 내용은 PHP 중국어 웹사이트의 관련 기사를 참고하세요!


성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
WordPress 블록 및 요소에 상자 그림자를 추가합니다WordPress 블록 및 요소에 상자 그림자를 추가합니다Mar 09, 2025 pm 12:53 PM

CSS Box-Shadow 및 개요 속성은 주제를 얻었습니다. 실제 테마에서 어떻게 작동하는지에 대한 몇 가지 예와 이러한 스타일을 WordPress 블록 및 요소에 적용 해야하는 옵션을 보자.

GraphQL 캐싱 작업GraphQL 캐싱 작업Mar 19, 2025 am 09:36 AM

최근에 GraphQL 작업을 시작했거나 장단점을 검토 한 경우 "GraphQL이 캐싱을 지원하지 않음"또는

첫 번째 맞춤형 전환을 만듭니다첫 번째 맞춤형 전환을 만듭니다Mar 15, 2025 am 11:08 AM

Svelte Transition API는 맞춤형 전환을 포함하여 문서를 입력하거나 떠날 때 구성 요소를 애니메이션하는 방법을 제공합니다.

고급스럽고 멋진 커스텀 CSS 스크롤 바 : 쇼케이스고급스럽고 멋진 커스텀 CSS 스크롤 바 : 쇼케이스Mar 10, 2025 am 11:37 AM

이 기사에서 우리는 스크롤 바의 세계로 뛰어들 것입니다. 너무 화려하게 들리지는 않지만 잘 설계된 페이지가 손을 잡고 있습니다.

쇼, 말하지 마십시오쇼, 말하지 마십시오Mar 16, 2025 am 11:49 AM

웹 사이트의 컨텐츠 프레젠테이션을 설계하는 데 얼마나 많은 시간을 소비합니까? 새 블로그 게시물을 작성하거나 새 페이지를 만들 때

Redwood.js 및 동물 군을 사용하여 이더 리움 앱 구축Redwood.js 및 동물 군을 사용하여 이더 리움 앱 구축Mar 28, 2025 am 09:18 AM

최근 Bitcoin의 가격이 20k 달러가 넘는 USD가 최근에 등반되면서 최근 30k를 끊었으므로 Ethereum을 만드는 데 깊이 다이빙을 할 가치가 있다고 생각했습니다.

NPM 명령은 무엇입니까?NPM 명령은 무엇입니까?Mar 15, 2025 am 11:36 AM

NPM 명령은 서버 시작 또는 컴파일 코드와 같은 것들에 대한 일회성 또는 지속적으로 실행되는 프로세스로 다양한 작업을 실행합니다.

특이성에 대해 이야기하기 위해 (X, X, X, X)를 사용해 보겠습니다.특이성에 대해 이야기하기 위해 (X, X, X, X)를 사용해 보겠습니다.Mar 24, 2025 am 10:37 AM

나는 다른 날에 Eric Meyer와 대화를 나누고 있었고 나는 내 형성 시절부터 Eric Meyer 이야기를 기억했습니다. CSS 특이성에 대한 블로그 게시물을 썼습니다

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

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

PhpStorm 맥 버전

PhpStorm 맥 버전

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

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

에디트플러스 중국어 크랙 버전

에디트플러스 중국어 크랙 버전

작은 크기, 구문 강조, 코드 프롬프트 기능을 지원하지 않음

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.