В примере выше присудив свойствам margin и padding по одному значению, мы определили поля и отступы элемента со всех четырех его сторон. Для того чтобы указать разные размеры полей и отступов для каждой из сторон элемента, необходимо указывать два, три или четыре аргумента через пробел. Причем в зависимости от количества значений результат будет разным.
Вот примеры:
margin: 5px; - одно значение. Одно значение - Поля одинаковые со всех сторон.
margin: 5px 40px; - два значения. Первое значение - Устанавливает поля от верхней и нижней границ. Второе значение - Устанавливает поля от левой и правой границ элемента.
margin: 5px 40px 20px;- три значения. Первое значение - Устанавливает поле от верхней границы элемента. Второе значение - Устанавливает поля от левой и правой границ элемента. Третье значение - Устанавливает поле от нижней границы элемента.
margin: 5px 40px 20px 1px; - четыре значения. Первое значение - Устанавливает поле от верхней границы элемента. Второе значение - Устанавливает поле от правой границы элемента. Третье значение - Устанавливает поле от нижней границы элемента. Четвёртое значение - Устанавливает поле от левой границы элемента.
С padding дело происходит по тому же принципу, как и с margin, отступы от внутренних границ элемента до содержания приобретают размеры в зависимости от количества аргументов и их значений.
Пример:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title>Поля и отступы</title> <style type="text/css"> div.block1 { width: 260px; background-color: #c5ffa0; border: 2px solid #a68754 } div.block2 { background-color: #c0e4ff; border: 2px solid #a68754; margin: 20px 5px 20px 40px; padding: 5px 25px } </style> </head> <body> <div class="block1"> <div class="block2"> <samp>Осмысливая мысли в смысле смысла, есть смысл помыслить о немыслимом!</samp> </div> <div class="block2"> <samp>Мало кто знает, как много надо знать, для того чтобы знать, как мало мы знаем!</samp> </div> </div> </body> </html>