문서의 이전 판입니다!
clear 속성은 어떤 요소가 지워진 요소 옆과 어떤 방향에서 떠 있을 수 있는 지를 지정합니다.
clear 속성은 하기의 값들 중 하나를 가질 수 있습니다.
clear속성을 사용하는 가장 일반적인 방법은 요소에 float속성을 사용한 이후입니다.
float를 지울 때 clear를 float에 일치시켜야 합니다: 요소가 좌측으로 float될 경우, 좌측으로 지워야 합니다. float된 요소가 계속 float되지만, 지워진 요소는 웹 페이지에서 그 아래에 표시됩니다.
하기의 예제는 좌측으로의 float를 지웁니다. .div의 좌측에 플로팅 요소가 허용되지 않음을 의미합니다.
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Without/With clear</title> <style> .div1 { float: left; width: 100px; height: 50px; margin: 10px; border: 3px solid green; } .div2 { border: 2px solid red; } .div3 { float: left; width: 100px; height: 50px; margin: 10px; border: 3px solid green; } .div4 { border: 2px solid red; clear: left; } </style> </head> <body> <h2>Without clear</h2> <div class="div1"><strong>div1</strong></div> <div class="div2"> <strong>div2</strong> - Notice that div2 is after div1 in the HTML code. However, since div1 floats to the left, the text in div2 flows around div1................................................. </div> <br><br> <h2>With clear</h2> <div class="div3"><strong>div3</strong></div> <div class="div4"><strong>div4</strong> - Here, clear: left; moves div4 down below the floating div3. The value "left" clears elements floated to the left. You can also clear "right" and "both". </div> </body> </html>
어떤 한 요소가 자신을 포함하고 있는 요소보다 크고 float된 경우, 컨테이너 외부로 넘치게 됩니다.
그리고 나서, 이 문제를 해결하기 위해, 요소를 포함하는 것에 overflow: auato속성을 추가할 수 있습니다.
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Clearfix</title> <style> div { border: 3px solid green; padding: 5px; } .img1 { float: right; } .clearfix { overflow: auto; } .img2 { float: right; } </style> </head> <body> <h2>Clearfix</h2> <p> In this example, the image is taller than the element containing it, and it is floated, so it overflows outsie of its container: </p> <div> <img class="img1" src="pineapple.jpg" alt="pineapple" width="170" height="170"> Lorem ipsum dolor sit amet, consectetur adipiscing elit. Phasellus imperdiet, nulla et dictum interdum... </div> <p style="clear:right"> Add a clearfix class with overflow: auto; to the containing element, to fix this problem: </p> <div class="clearfix"> <img class="img2" src="pineapple.jpg" alt="pineapple" width="170" height="170"> Lorem ipsum dolor sit amet, consectetur adipiscing elit. Phasellus imperdiet, nulla et dictum interdum... </div> </body> </html>
overflow: auto clearfix는 마진과 패딩을 제어할 수 있는 한 잘 작동합니다.(그렇지 않을 경우, 스크롤 막대가 표시될 수 있슴). 그러나 새롭고 현대적인 clearfix hack은 사용하기에 더 안전하며, 대부분의 웹페이지에서 하기의 코ㅡ가 사용됩니다.
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Clearfix</title> <style> div { border: 3px solid green; padding: 5px; } .img1 { float: right; } .clearfix::after { content: ""; clear: both; display: table; } .img2 { float: right; } </style> </head> <body> <p> In this example, the image is taller than the element containing it, and it is floated, so it overflows outsie of its container: </p> <div> <h2>Without Clearfix</h2> <img class="img1" src="pineapple.jpg" alt="pineapple" width="170" height="170"> Lorem ipsum dolor sit amet, consectetur adipiscing elit. Phasellus imperdiet, nulla et dictum interdum... </div> <p style="clear:right"> Add a clearfix class with overflow: auto; to the containing element, to fix this problem: </p> <div class="clearfix"> <img class="img2" src="pineapple.jpg" alt="pineapple" width="170" height="170"> Lorem ipsum dolor sit amet, consectetur adipiscing elit. Phasellus imperdiet, nulla et dictum interdum... </div> </body> </html>