CSS with Standards | Page Layout Series Part IICSS with StandardsÁö³ ÆäÀÌÁö(Page layout & DTD)¿¡´Â, IE 6.0¿¡¼ÀÇ DTD mode ¼±¾ð¿¡ µû¶ó 150 pixel Á¤»ç°¢ÇüÀÇ border°¡ ´Ù¸£°Ô rendering µÈ´Ù´Â »ç½ÇÀ» È®ÀÎÇÑ ¹Ù ÀÖ½À´Ï´Ù. À̹ø ÆäÀÌÁö¿¡¼´Â border¿Í ÇÔ²² CSS box model°ú °ü°èµÈ ³ª¸ÓÁö CSS propertyÀÎ margin°ú padding¿¡ ´ëÇØ¼ ÁýÁßÀûÀ¸·Î ¾Ë¾Æ º¸µµ·Ï Çϰڴµ¥ ±×¿¡ ¾Õ¼¼ ¶Ç ÇѰ¡Áö ¤°í ³Ñ¾î°¡¾ßÇÒ Ç¥ÁØ ¸ðµå¿Í ºñ Ç¥ÁØ ¸ðµåÀÇ Áß¿äÇÑ Â÷ÀÌÁ¡ÀÌ ÀÖ½À´Ï´Ù. ±× Â÷ÀÌÁ¡Àº ¹Ù·Î Ç¥ÁØ ¸ðµå¿Í ºñ Ç¥ÁØ ¸ðµå °¢°¢¿¡¼ È¸é »ó¿¡ renderingµÇ´Â ÃÖ»óÀ§ element°¡ ¾î¶² element³Ä ÇÏ´Â ¹®Á¦ ÀÔ´Ï´Ù. ¿©·¯ºÐµéÀÌ ÀÍÈ÷ ¾Ë°í ÀÖ´Ù½ÃÇÇ ¾Æ·¡¿Í °°ÀÌ <html>ÀÌ ÃÖ»óÀ§ elementÀ̰í, ±× ¹®¼ÀÇ Á¤º¸¿Í style block, script block, meta element, link µî¿¡ ´ëÇØ ±â¼úÇÏ´Â <head> section°ú ½ÇÁ¦ÀûÀ¸·Î ȸ鿡 rendering µÇ´Â <body> sectionÀÌ ÀÖ½À´Ï´Ù. Áï, html elemnt´Â html ¹®¼°¡ <html>¿¡¼ ½ÃÀÛÇØ¼ </html> ¿¡¼ ³¡³´Ù´Â markupÀ» ÇÏ´Â ¿ªÇÒ¸¸À» ÇÏ´Â °ÍÀ¸·Î »ý°¢ÇÏÁö¸¸, ±×°Ç ¾îµð±îÁö³ª DTD¸¦ ¼±¾ðÇÏÁö ¾Ê°Å³ª DTD¸¦ Ç¥ÁØ ¸ðµå·Î ¼±¾ðÇÏÁö ¾Ê¾ÒÀ» °æ¿ìÀ̰í, Standard-compliant mode¿¡¼´Â html elementµµ ȸ鿡 rendering µÈ´Ù´Â »ç½ÇÀÔ´Ï´Ù. È®ÀÎÀ» À§Çؼ ¾Æ·¡¿Í °°ÀÌ html code¸¦ Ç¥ÁØ ¸ðµå¿Í ºñÇ¥ÁØ ¸ðµå·Î !DOCTYPE ¼±¾ðÀ» ¹Ù²ã¼ °¢°¢ ½ÇÇàÇØ º¸½ÃÁÒ. ÀÔ·Â
<DTD ¼±¾ð ºÎºÐ>
<html style="background-color:tomato;">
<head>
<title>Ç¥ÁØ ¸ðµå¿Í ºñÇ¥ÁØ ¸ðµå¿¡¼ÀÇ TopElement</title>
</head>
<body style="background-color:gold; width:200px; height:200px; margin:50px; padding:25px;">
<div style="width:200px; height:200px; background-color:royalblue;"></div>
</body>
</html>
ÀÌ¿Í °°ÀÌ Ç¥ÁØ ¸ðµå¿¡¼´Â ȸé»ó¿¡ renderingµÇ´Â ÃÖ»óÀ§ element°¡ <html>ÀÌ°í ºñÇ¥ÁØ ¸ðµå¿¡¼´Â <body>¶ó´Â»ç½ÇÀÔ´Ï´Ù. ÀÌ »ç½ÇÀº µÚ¿¡ ´Ù·ê positioning¿¡¼ Ä¿´Ù¶õ Â÷À̸¦ º¸ÀÌ°Ô µË´Ï´Ù. ¶ÇÇÑ DTD¸¦ Ç¥ÁØ ¸ðµå·Î ¼±¾ðÇϰí, <html>¿¡ background-color¸¦ ÁöÁ¤ÇÏÁö ¾Ê¾ÒÀ» °æ¿ì, <body>¿¡ ÁöÁ¤µÈ background-color °¡ ȸ鿡 rendering µË´Ï´Ù. ÀÌÁ¦ ÀÌ ÆäÀÌÁö¿¡¼ ´Ù·ê ³»¿ëÀÎ padding, border, margin À¸·Î µ¹¾Æ¿Í¼, ¿ì¸®°¡ ¾Õ ÆäÀÌÁö¿¡¼ È®ÀÎÇÑ ¹Ù¿Í °°ÀÌ Ç¥ÁØ ¸ðµå(Standard-compliant mode)¿Í ºñÇ¥ÁØ ¸ðµå(Non standard-compliant mode)¿¡¼ rendering µÈ borderÀÇ width¸¦ ºñ±³ÇØ º¸¸é ¾Æ·¡¿Í °°ÀÌ
ÀÌ·¸°Ô Á¤¸®ÇÒ ¼ö ÀÖ°Ú½À´Ï´Ù. ÀÌ¿Í °°ÀÌ ÁöÁ¤ÇÑ width¿Í height¸¦ ħ¹üÇÏ´À³Ä, ÇÏÁö ¾Ê´À³Ä ¶ó´Â Â÷À̸¦ ´Ù¸£°Ô Ç¥ÇöÇϸé, Ç¥ÁØ ¸ðµå¿¡¼ÀÇ renderingÀº ÁöÁ¤ÇÑ width¿Í height¸¦ ³»¿ë¹°(content)ÀÌ µé¾î°¥ ¼ö ÀÖµµ·Ï Ç×»ó È®º¸ÇØ ÁÖ¸ç, ºñÇ¥ÁØ ¸ðµå¿¡¼´Â ±×·¸Áö ¾Ê´Ù¶ó°í Ç¥ÇöÇÒ ¼ö ÀÖ°Ú½À´Ï´Ù. ¾Æ·¡ÀÇ DHTMLÀº ÀÌ¹Ì CSS / Layout / margin ¿¡¼ Ç¥ÇöÇß´ø DHTML·Î¼ content, padding, border, marginÀ» ³»ºÎ¿¡¼ ¿ÜºÎÀÇ ¼ø¼·Î Ç¥ÇöÇÑ ±×¸²ÀÌ µÇ°Ú½À´Ï´Ù. ÀÌ ±×¸²À» º¸°í ´Ù½Ã ÇÑ ¹ø °¢ ºÎºÐÀ» È®ÀÎÇÏ°í ´ÙÀ½ ¼³¸íÀ» º¸½Ã±â ¹Ù¶ø´Ï´Ù.
Ç¥ÁØ ¸ðµå¿Í ºñÇ¥ÁØ ¸ðµå¿¡¼ÀÇ paddingÀÇ rendering ºñ±³ÀÌÁ¦ À§ÀÇ ±×¸²À» º¸°í °¢ CSS property¸¦ ³ª¸§´ë·Î ¿ì¸®¸»·Î ¹Ù²ãº¸¸é
ÀÌ·¸°Ô Á¤ÀÇÇÒ ¼ö ÀÖ°Ú½À´Ï´Ù. ±×·¯¸é Áö±Ý ºÎÅÍ Ç¥ÁØ ¸ðµå¿Í ºñÇ¥ÁØ ¸ðµå¿¡¼ paddingÀÌ ¾î¶»°Ô rendering µÇ´ÂÁö ¾Ë¾Æ º¸°Ú½À´Ï´Ù. ±×·±µ¥ ÀÌ paddingÀÇ °æ¿ì padding band ºÎºÐ¸¸ bakcground-color¸¦ µû·Î ÁöÁ¤ÇÒ ¼ö ¾ø±â ¶§¹®¿¡ ÆíÀÇ»ó Ç¥ÇöÇϰíÀÚ ÇÏ´Â div¼Ó¿¡ ¶Ç ÇϳªÀÇ div¸¦ ³Ö°í, ¼Ó¿¡ µé¾î°£ divÀÇ background-color¸¦ ´Ù¸£°Ô ÁöÁ¤Çؼ ±¸º°Çϵµ·Ï ÇϰڽÀ´Ï´Ù. ÀÔ·Â <DTD ¼±¾ð ºÎºÐ> <html> <head> <title>content, padding, border, margin</title> </head> <body style="background-color: royalblue;margin:0px;"> <!-- width:150px; height:150px ÀÇ ±âÁØ div ½ÃÀÛ --> <div style="width:150px; height:150px;background-color:gold; border:10px solid tomato;padding:50px;margin:50px;"> <!-- paddingÀ» Ç¥ÇöÇϱâ À§ÇÑ div ½ÃÀÛ --> <div style="width:100%; height:100%;background-color:white;"> </div> </div> </body> </html> À§ codeÀÇ ½ÇÇà °á°ú¸¦ ºñ±³Çϸé Àü ÆäÀÌÁöÀÇ border¿Í ¸¶Âù°¡Áö·Î
¶ó´Â °á°ú°¡ ³ª¿É´Ï´Ù. µû¶ó¼ ºñÇ¥ÁØ ¸ðµåÀÇ °æ¿ì containing box°¢ 4 ¸é¿¡ ¸ðµÎ border¿Í paddingÀ» ÁöÁ¤Çϰí content ¸¦ ³ÖÁö ¾Ê¾Ò´Ù°í °¡Á¤ÇßÀ» ¶§,
<html>
<head>
<title>content, padding, border, margin</title>
</head>
<body style="background-color: royalblue;margin:0px;">
<div style="width:150px; height:150px;background-color:gold;
border:25px solid tomato;padding:50px;margin:50px;">
<div style="width:100%; height:100%;background-color:white;">
<!-- ºñ¾îÀÖ´Â content -->
</div>
</div>
</body>
</html>
marginmargin À̶õ ¾Õ¿¡¼ ¼³¸íÇÑ °Í ó·³ box ¿ÜºÎ¿¡ »ý±â´Â °ø°£À¸·Î¼, Á¦°¡ '¿ÜºÎ ¿©¹é' À̶ó°í Ç¥ÇöÇß½À´Ï´Ù. µû¶ó¼ ÀÌ marginÀÇ °æ¿ì´Â content boxÀÇ ³»ºÎ¸¦ ħ¹üÇÏÁö ¾Ê½À´Ï´Ù. ´Ù¸¸ marginÀÇ °æ¿ì ó·³ ¹®¼ ³»ÀÇ ´Ù¸¥ block level element ³ª text level elementµé°ú ¼·Î Á¢ÇÏ´Â ºÎºÐÀÌ ÀÖ´Â elementÀÇ °æ¿ì¿¡´Â ´Þ¶û box ÀÚü ¸¸À» »ý°¢Çؼ´Â ¾ÈµÇ°í ÀÎÁ¢ÇÑ ´Ù¸¥ element µé°úÀÇ »ó°ü °ü°è¸¦ Ç×»ó »ý°¢ÇØ¾ß µË´Ï´Ù. ±×·¡¼ ¾Æ·¡¿Í °°ÀÌ ÃÖ»óÀ§ div¸¦ Çϳª ¸¸µé°í, ±× ¾È¿¡ °°Àº class¸¦ °¡Áö´Â div¸¦ ¼öÁ÷À¸·Î 3°³ ³õ¾Æ º¸¾Ò½À´Ï´Ù. ¿ì¼± marginÀÌ Ç¥ÁØ ¸ðµå¿Í ºñÇ¥ÁØ ¸ðµå¿¡¼ ¾î¶»°Ô ´Ù¸¥Áö ½ÇÇà ºÎÅÍ ÇØ º¸½ÃÁÒ. margin
<DTD ¼±¾ð ºÎºÐ>
<html>
<head>
<title>content, padding, border, margin</title>
<style type="text/css">
<!--
.outerDiv{width:100%; height:100%;border:1px solid blue;}
.innerDiv{width:100px; height:100px; border:1px solid red; margin:25px;}
-->
</style>
</head>
<body>
<div class="outerDiv">
<div class="innerDiv"></div>
<div class="innerDiv"></div>
<div class="innerDiv"></div>
</div>
</body>
</html>
°á°ú¸¦ º¸¸é width, height °ªÀ» 100%·Î ÁÖ¾úÀ» ¶§ Ç¥ÁØ ¸ðµå¿Í ºñÇ¥ÁØ ¸ðµåÀÇ 100%¿¡ ´ëÇÑ rendering ¸éÀûÀÌ ´Ù¸¥ °Í ¸»°í´Â °°Àº °á°ú ÀÔ´Ï´Ù. NNÀ̳ª FF¿¡¼µµ °°Àº °á°ú°¡ ³ª¿À´õ±º¿ä. ÀÌ ºÎºÐ¿¡¼ ´«¿©°Ü º¸¾Æ¾ß ÇÒ °ÍÀº Ç¥ÁØ ¸ðµå¿Í ºñÇ¥ÁØ ¸ðµå °øÈ÷ box ¼·Î °£ÀÇ marginÀÌ 25px ¶ó´Â »ç½ÇÀÔ´Ï´Ù. marginÀ» 25px·Î ÁöÁ¤ÇßÀ¸´Ï ´ç¿¬ÇÑ °á°úÀÔ´Ï´Ù¸¸ box °¡ ¼·Î ¸¸³ª´Â ºÎºÐµµ marginÀÌ 25px ¶ó´Â »ç½Ç ÀÔ´Ï´Ù. Áï, box °¢°¢¿¡ 25px ÀÇ marginÀ» ÁöÁ¤Çß´Ù°í ÇØ¼ ¸¸³ª´Â ºÎºÐÀÌ 25px + 25px = 50px °¡ ¾Æ´Ï¶ó 25px ¶ó´Â °ÅÁÒ. ±×·¯¹Ç·Î marginÀº ¾çÂÊ box¿¡ °¢°¢ÀÇ °ªÀ» ÁöÁ¤ÇßÀ» ¶§ ¾Æ·¡ÀÇ ¿¹Á¦¿Í °°ÀÌ Å« °ªÀÌ °á°úÀûÀ¸·Î Àû¿ëµË´Ï´Ù. margin °ªÀÇ °è»ê
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.0 Strict//EN"
"http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<title>content, padding, border, margin</title>
<style type="text/css">
<!--
.outerDiv{width:100%; height:100%;border:1px solid blue;}
.innerDiv{width:100px; height:100px; border:1px solid red; margin:25px;}
-->
</style>
</head>
<body>
<div class="outerDiv">
<div class="innerDiv" style="margin-bottom:50px;"></div>
<div class="innerDiv" style="margin-left:-50px;"></div>
<div class="innerDiv" style="margin-top:50px;"></div>
</div>
</body>
</html>
¾î¶»½À´Ï±î. Å« °ª¸¸ ¸¸Á· ½ÃŰ¸é µÇÁÒ? ¶ÇÇÑ padding°ú marginÀÇ ¶Ç ´Ù¸¥ Â÷ÀÌÁ¡Àº paddingÀº - (minus) °ªÀ» °¡Áú ¼ö ¾øÁö¸¸ marginÀº - °ªÀ» °¡Áú ¼ö ÀÖ´Ù´Â »ç½Ç ÀÔ´Ï´Ù. Block level element ÀÇ intrinsic margin valueIntrinsic value¿¡¼ intrinsic À̶õ ´Ü¾î´Â »çÀüÀû Àǹ̷δ '°íÀ¯ÀÇ', 'º»ÁúÀûÀÎ', 'º»·¡ °®Ãß°í ÀÖ´Â' À̶ó´Â ¶æÀ» Áö´Ñ ´Ü¾î·Î¼ ¿©±â¼´Â 'ÁöÁ¤ÇÏÁö ¾Ê¾Æµµ ¿ø·¡ °¡Áö°í ÀÖ´Â' À̶ó´Â ¶æÀ¸·Î Ç®ÀÌÇÏ¸é µÇ°Ú½À´Ï´Ù. Áï, block level element ÀÇ intrinsic margin value ´Â 'ÁöÁ¤ÇÏÁö ¾Ê¾Æµµ block level element°¡ ¿ø·¡ °¡Áö°í ÀÖ´Â margin °ª' À̶ó°í ÇØ¼® ÇϰڽÀ´Ï´Ù. ±×·±µ¥ ÀÌ intrinsic margin valueÀÇ °æ¿ì °°Àº block level element ¶óµµ ´Ù¼ÒÀÇ Â÷À̸¦ °¡Áö°í ÀÖ½À´Ï´Ù. ¾Æ·¡ÀÇ ¿¹Á¦¸¦ ½ÇÇàÇØ º¾½Ã´Ù. Block level element ÀÇ intrinsic margin value
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Strict//EN">
<html>
<head>
<title>Intrinsic margin value</title>
<style type="text/css">
<!--
table, h1, p, div, form, blockquote, dl, dt, dd{border:1px solid tomato;}
-->
</style>
</head>
<body>
<h1>Heading 1</h1>
<p>Paragraph</p>
<div>DIVision marker</div>
<table width="300">
<tr>
<td>table</td>
</tr>
</table>
<blockquote>blockquote</blockquote>
<dl>Definition List
<dt>Definition Term</dt>
<dd>Definition Data</dd>
</dl>
<form>form</form>
</body>
</html>
À§ÀÇ ¿¹Á¦¿Í °°ÀÌ element¸¶´Ù border¸¦ ÁöÁ¤ÇØ º¸¸é °¢ block level element ¸¶´Ù °¡Áö´Â intrinsic margin value ¸¦ È®ÀÎÇÒ ¼ö Àִµ¥ ÀÌ °Íµé Áß¿¡¼ table, div, dt, dd¿Í °°ÀÌ intrinsic margin value°¡ '0' ÀÎ element¿Í p, blockquote, dl, form µî°ú °°ÀÌ ´ë·« 19px(FF¿¡¼´Â ¾à 16px) Á¤µµÀÇ intrinsic margin value¸¦ °¡Áö´Â element°¡ ÀÖ´Â °ÍÀ» ¾Ë ¼ö ÀÖ½À´Ï´Ù. ¶Ç ƯÀÌÇϰԵµ blockquote ÀÇ °æ¿ì¿¡´Â »óÇÏ(margin-top, margin-bottom)¿¡¸¸ marginÀÌ »ý±â´Â°Ô ¾Æ´Ï¶ó Á¿ì(margin-left, margin-right)¿¡µµ marginÀÌ »ý±ä´Ù´Â °ÅÁÒ. ¹°·Ð ÀÌ °æ¿ì¿¡µµ p, blockquote ¿Í °°ÀÌ 19px Á¤µµÀÇ »óÇÏ marginÀ» °¡Áö´Â °æ¿ìµµ À§ÀÇ 'margin °ªÀÇ °è»ê'¿¡¼ ¼³¸íÇÑ °Í°ú °°ÀÌ 19px + 19px = 36px ¿Í °°ÀÌ °è»ê ÇÏ´Â°Ô ¾Æ´Ï¶ó µÑ Áß¿¡ Å« °ªÀÌ ÀÖÀ¸¸é Å« °ªÀ», µÑÀÌ °°Àº °ªÀÌ¸é °°Àº °ª ¸¸Å¸¸ marginÀÌ »ý±é´Ï´Ù. ÀÌ¿Í °°ÀÌ ¾î¶² block level elementÀÇ marginÀ» ´«À¸·Î È®ÀÎÇÏ°í ½ÍÀ¸¸é border ¶Ç´Â background-colorµîÀ» ÁöÁ¤ÇÏ¿© º¸´Ù Çö½Ç°¨ÀÖ°Ô °¢ block level element°¡ °¡Áö´Â intrinsic margin value¸¦ È®ÀÎ ÇØº¼ ¼ö ÀÖ°Ú½À´Ï´Ù. ±×·³ PLS part III ¿¡¼... ÀÌ ¹®¼ÀÇ ÀúÀÛ±ÇÀº www.cadvance.org ¿¡ ÀÖ½À´Ï´Ù.
|