Войти
Windows. Программы. Железо. Интернет. Безопасность. Мой компьютер
  • Конструктор Arduino: новый взгляд сквозь SparkFun Pro Micro Arduino pro micro как работает
  • Ожидания и реалии в CRM-проектах Безапелляционный detail php id
  • Как узнать IMEI (серийный номер) iPhone?
  • Оптимизация OS X для продления жизни SSD
  • Функциональные устройства на операционных усилителях линейные аналоговые вычислительные схемы на оу Что такое аналоговая микросхема
  • Не высвечивается дисковод
  • Отступы и поля в html. Текстовые поля. Дочерние свойства margin и padding

    Отступы и поля в html. Текстовые поля. Дочерние свойства margin и padding

    В этой главе мы поговорим о полях (свойство margin ) и отступах (свойство padding ) элемента. Между собой эти два свойства весьма схожи, однако все же это два абсолютно разных свойства.

    Давайте разберемся в этих понятиях..

    Поле (margin ) - Это расстояние от внешней границы элемента до границы окна браузера или же элемента родителя.. ну границы того блока в который вложен наш элемент.

    Отступом (padding ) - Называют расстояние от внутренней границы элемента до его содержания текста, картинок таблиц..

    На рисунке наглядно показаны эти расстояния, а так же место занимаемое бордюром (border ) про него тоже не следует забывать.

    Расстояния margin и padding указываются:

    • px - В пикселях или любых других допустимых CSS единицах измерения.
    • % - В процентах.
    • auto - Размер полей и отступов автоматически рассчитывается браузером.

    Давайте попробуем сделать тоже самое, что показано на рисунке с помощью блоков

    и свойств CSS.




    Поля и отступы










    Попробуйте поменять значения свойств margin и padding и Вы поймете, что к чему.. а если и так понятно идем дальше..

    Возможные значения margin и padding.

    В примере выше присудив свойствам margin и padding по одному значению, мы определили поля и отступы элемента со всех четырех его сторон. Для того чтобы указать разные размеры полей и отступов для каждой из сторон элемента, необходимо указывать два, три или четыре аргумента через пробел. Причем в зависимости от количества значений результат будет разным.

    Вот примеры:

    margin: 5px ; - одно значение .
    Одно значение - Поля одинаковые со всех сторон.

    margin: 5px 40px; - два значения.
    Первое значение - Устанавливает поля от верхней и нижней границ.

    margin: 5px 40px 20px; - три значения.
    Второе значение - Устанавливает поля от левой и правой границ элемента.

    margin: 5px 40px 20px 1px; - четыре значения.
    Первое значение - Устанавливает поле от верхней границы элемента.
    Второе значение - Устанавливает поле от правой границы элемента.
    Третье значение - Устанавливает поле от нижней границы элемента.
    Четвёртое значение - Устанавливает поле от левой границы элемента.

    С padding дело происходит по тому же принципу, как и с margin , отступы от внутренних границ элемента до содержания приобретают размеры в зависимости от количества аргументов и их значений.




    Поля и отступы





    Осмысливая мысли в смысле смысла, есть смысл помыслить о немыслимом!







    Дочерние свойства margin и padding.

    Свойства CSS margin и padding являются базовыми и имеют ряд дочерних свойств.

    У margin зто:

    • margin-top - Поле от верхней границы элемента родителя,
    • margin-left - Поле от левой границы элемента родителя,
    • margin-right - Поле от правой границы элемента родителя,
    • margin-bottom - Поле от нижней границы элемента родителя.

    И у padding соответственно:

    • padding-top - Отступ от верхней границы элемента до его содержания,
    • padding-left - Отступ от левой границы элемента до его содержания,
    • padding-right - Отступ от правой границы элемента до его содержания,
    • padding-bottom - Отступ от нижней границы элемента до его содержания.

    Ну думаю понятно.. если возникает необходимость определить отступ или поле от одной единственной стороны элемента лучше воспользоваться одним из вышеперечисленных свойств.




    Поля и отступы




    Осмысливая мысли в смысле смысла, есть смысл помыслить о немыслимом!



    Мало кто знает, как много надо знать, для того чтобы знать, как мало мы знаем!




    Поля и отступы являются одними из основных составляющих дизайна сайта, по этому поводу следует придерживаться нескольких рекомендаций.

      Избегайте коротких, и уж тем более, нулевых отступов от содержимого к границам элемента, особенно это касается текстовых блоков. Текст с маленькими полями и отступами читается трудно и "вязко".

      Соблюдайте правила пропорциональности и соизмеримости полей и отступов как для отдельно взятого элемента, так и для всей страницы (композиции элементов) целиком.

      Один из способов акцентирования внимания посетителя страницы на нужном Вам месте - это отступы размером больше обычного, такой контраст заставит зрителя смотреть и проявить внимание к "особым" местам в тексте..

    Математика в CSS не работает. Например, есть заголовок (тег h1) и за ним следует абзац (тег p). Оба элемента блочные, из чего следует, что их ширина равна элементу-родителю и в потоке они расположены один под другим. Также представим, что заголовок имеет нижнее поле (margin-bottom) равное 30px, а абзац – верхнее поле (margin-top) равное 50px. Казалось бы, промежуток между заголовком и абзацем должен быть равен сумме этих двух полей, то есть 80px, однако нет. Соседние поля не складываются, браузер просто выбирает наибольшее из двух значений, в нашем случае 50px. Поэтому, если вы хотите сделать промежуток между двумя элементами при участии двух элементов, используйте отступы (padding).

    Заголовок. Присутствует нижнеее поле в 30px

    Абзац. Есть верхнее поле в 50px

    Или вот ситуация: в блоке div лежит абзац (тег p), у абзаца присутствуют верхнее и нижнее поля (margin-top и margin-bottom) равные 50px. Казалось бы, под действием этих полей блок div должен расшириться, однако нет. Поля выступают за пределы блока div (рис. 1). Данный эффект называется конфликтом полей. Чтобы избежать выхода поля за пределы блочного элемента, необходимо элементу-родителю (в нашем случае тегу div) назначить верхний и нижний отступы (padding) равные, например, 1 px. Или границу (border).

    Абзац. Есть верхнее и нижнеее поле в 50px


    Или вы можете использовать свойство overflow для элемента-родителя со значением отличным от visible: этим вы также предотвратите выход поля элемента-ребенка за пределы элемента-родителя.

    Padding-top

    Со структурой блока, надеюсь, Вы уже знакомы. Если нет, то она представлена ниже.

    Структура блока

    И так. Вам уже, наверное, известно, что поля и отступы у блока представлены свойствами padding и margin соответственно. И в предыдущей статье мы уже частично затронули эту тему. На этой странице немного подробнее рассмотрим поля (padding ) и отступы (margin ).

    Свойства margin и padding очень похожи друг на друга, выполняют схожие функции, поэтому их часто путают. Но делать этого конечно же не стоит, так как все-таки поля и отступы это совершенно разные вещи. Впрочем это хорошо видно из рисунка, ведь не случайно он здесь приведен.

    Итак. Поля задаются свойством padding . Это внутренние расстояния от границ блока до его содержимого.

    Свойство применимо ко всем элементам.

    Расстояние задается в единицах длины, принятых в CSS , в % , либо (по умолчанию

    Свойство padding является универсальным, так как устанавливает поля от границ элемента до его содержимого для всех его сторон, объединяя таким образом в себе свойства padding-top , padding-right , padding-bottom и padding-left , которые задают ширину полей для каждой из сторон элемента индивидуально.

    Отступы задают при помощи свойства margin , которые определяют расстояние от границ блока до ближайших элементов или до краев окна браузера.

    Свойство margin также применимо ко всем элементам.

    Отступы также задаются в единицах длины, принятых в CSS , в % , либо (по умолчанию ) определяется браузером автоматически.

    Свойство margin является универсальным, так как задает величину отступов от границ элемента для всех его сторон, объединяя таким образом в себе свойства margin-top , margin-right , margin-bottom и margin-left , которые устанавливают ширину отступов от каждой из границ элемента индивидуально.

    И еще : отступы (margin ) располагаются за пределами блока, в то время как поля (padding ) внутри его, поэтому фон блока или его фоновое изображение распространяются только на поля, а отступы всегда прозрачны, либо имеют фон основного (родительского ) блока или фон страницы.

    Фрагмент кода:



    ; ">

    Таблица располагается внутри контейнера с красной границей и синим фоном.


    Ширина отступов от границы таблицы до красной границы контейнера составляет 10 пикселей.


    В ячейке слева расположено изображение. Отступы от изображения до границ ячейки составляют 25 пикселей.


    Поля правой ячейки составляют 10 пикселей!


    Поля и отступы являются очень важными стилями при построении HTML-страницы. Они позволяют более точно спозиционировать элементы, создать каркас с необходимыми зазорами и т.п. Оба стиля очень похожи и выполняют схожие функции. Но отличия все же есть.

    Элементы могут быть вложенными, могут находиться по соседству друг от друга. Давайте рассмотрим следующий пример:

    Имеем две таблицы, лимонного и голубого цвета, расположенные друг под другом. Таблицы состоят из одной ячейки. В ячейке первой таблицы находится красный блок. На этом примере рассмотрим принцип работы полей и отступов.

    Поля задаются стилем padding . Этот стиль применим только к элементам-контейнерам, которые могут содержать в себе другие элементы. Стиль позволяет задать значение полей между краями элемента и его содержимым. Стиль margin позволяет задать отступы от элемента до ближайших границ другого элемента. Границами другого элемента могут быть границы родительского контейнера, а также края самой страницы.

    Существует несколько способов задания этих стилей. Например, непосредственно указать размер всех полей или отступов одним аргументом в какой-нибудь единице измерения (px, ex, em, pt, cm и так далее):

    padding : 3px ; margin : 3px ;

    В этом случае поля и отступы будут со всех четырех сторон одинаковы. При задании двух аргументов через пробел:

    padding : 3px 5px ; margin : 3px 5px ;

    первый будет определять величину полей/отступов сверху и снизу, второй - слева и справа. При задании трех аргументов:

    padding : 3px 5px 2px ; margin : 3px 5px 2px ;

    первый - поле/отступ сверху, второй - одновременно слева и справа, третий - снизу. При четырех аргументах:

    padding : 3px 5px 2px 6px ; margin : 3px 5px 2px 6px ;

    первый - поле/отступ сверху, второй - справа, третий - снизу, четвертый - слева. Легко запомнить: первый - сверху, далее по часовой стрелке. Кроме того, можно задавать поля и отступы для конкретного края отдельно, с помощью соответствующих стилей: padding-top , padding-right , padding-bottom , padding-left , margin-top , margin-right , margin-bottom , margin-left . Значением этих стилей может быть только один аргумент, задающий величину поля/отступа для данной стороны.

    На рисунке красный блок находится внутри ячейки таблицы и примыкает к ее границам, то есть поля у ячейки отсутствуют. Зададим поля ячейке с помощью стиля:

    padding : 5px ;

    В результате страница изменит вид к следующему:

    Рассмотрим теперь отступы. Две таблицы примыкают друг к другу, если мы хотим их немного раздвинуть, можно применить отступы. Тут есть два варианта: либо задать нижний отступ первой таблицы, либо верхний отступ второй таблицы. Давайте воспользуемся вторым:

    margin-top : 5px ;

    Заметьте, что отступ мы задаем именно таблице, а не ячейке таблицы, как в случае с полями. Вот результат:

    Кстати, в первом случае (зазор между красным блоком и границами родительской ячейки) того же самого эффекта можно было добиться с помощью задания отступов блока. В общем, если что-то непонятно, отписываемся в комментариях.

    HTML-код подопытной страницы:

    <html > <head > <title > Тест</ title > <meta http-equiv = "Content-Type" content = "text/html;charset=utf-8" > </ head > <body > <style > table {width: 200px; height: 150px; border: 1px solid #555; border-collapse: collapse} td {vertical-align: top; padding: 0px} div {width: 100px; height: 100px; background: red} </ style > <table style = "background: lime" > <tr > <td style = "padding: 5px" > <div style = "margin: 0px" > </ div > </ td > </ tr > </ table > <table style = "background: skyblue; margin-top: 5px" > <tr > <td > </ td > </ tr > </ table > </ body > </ html >

    Урок 9. Отступы (поля) вокруг объектов в CSS.

    Дата: 2009-04-22

    Сегодня используя стили CSS мы научимся делать поля и отступы вокруг объектов. Что мы будем называть объектами? Объектами или как иногда говорят контейнерами можно назвать все что угодно - это может буть абзац с текстом, картинка (графический файл), таблица, строка в таблице и т.д. Т.е. - это абсолютно любой элемент оформления на web-странице. Давайте для простоты определимся, что у нас объектом - будет абзац с текстом заключенным в теги .

    Создаем новый класс например .pol , и в фигурных {} скобках начинаем писать код стиля. Первое свойство:

    margin: 60px; - задает отступ со всех сторон вокруг абзаца (контейнера) в 60 px , естественно 60 px - взято для примера эта цифра может быть любая которая Вам больше подходит в каждом конкретном случае. Есть и варианты, а именно:

      margin-left: - отступ слева;

      margin-top: - отступ сверху;

      margin-right: - отступ справа;

      margin-bottom: - отступ снизу.

    Естественно можно применять эти значения в любом сочетании, например задать отступ слева и снизу (прописав в стиле значения margin-left: и margin-bottom: ) или только сверху (margin-top: ) и т.д. Еще свойство margih может принимать значение auto , которой прописывается так:

    Листинг 9.1.

    Что мы записали? Эта запись означает - мы задали рамку черного цвета вокруг нашего абзаца с текстом толщиной в 1 px и задали отступ текста от рамки 30px со всех сторон.

    Так же как и преведущее свойство margih , свойство padding: имеет варианты:

      padding-left: - отступ слева;

      padding-top: - отступ сверху;

      padding-right: - отступ справа;

      padding-bottom: - отступ снизу.

    Напоминаю что все эти свойство задают отступ внутри контейнера (от рамки до текста в нашем случае) применять их можно так же, по отдельности или в любых сочетаниях.

    Раз уж мы заговорили о контейнерах, давайте вспомним, как можно задать контейнер с заданными размерами, например нам на web-странице нужно вставить рекламный блок заданной ширины (width) и высоты (height) . Создаем новый класс .pol2 и пишем код:

    Листинг 9.3.

    Выровняв наш рекламный блок таким образом, мы замечаем, что "обтекающий" текст "прилип" к рамке рекламного блока. Значит нужно задать отступ от рамки блока. Делается это с помощью уже знакомого атрибута margin-right: . Вот как выглядит листинг кода.