Border двойная рамка. Рамки и границы

Михаил 2016-06-11 1 HTML и CSS 0

Как делается в css двойная рамка?

Всем привет. А вы знаете, как делать в css двойную рамку? Если нет, то прошу ознакомиться с этой небольшой заметкой. Дело в том, что это не сделаешь с помощью обычного border , тут нужно идти другим путем.

Если вы задаете рамку с помощью свойства border , то можете задать ее только одну. Но очень часто по дизайну может требоваться несколько рамок. В таком случае стоит воспользоваться псевдорамкой — тенью.

Двойная рамка с помощью box-shadow

Вообще если вы хотите подробнее изучить тень в css, то советую вам прочитать на соответствующую тему. В этой статье я не буду подробно объяснять синтаксис свойства, а просто покажу прием, как создать двойную рамку. Итак, создам обыкновенный блок, которому пропишу некоторые стили. Блок может быть любым и с любым содержимым. В моем случае это простой div, поэтому html код я даже не буду показывать. А вот стили:

Div{
background: #E0D8A3;
width: 180px;
height: 110px;
padding: 12px;
}

Ну типичный пример оформления блока.
Теперь создадим двойную рамку с помощью множественных теней. Добавлю в стили к блоку еще такое свойство:

Box-shadow: 0 0 0 1px #000, 0 0 0 10px #E0D8A3;

Вот так это выглядит:

Как видите, получилось достаточно симпатично. В box-shadow всего 5 параметров. Первый — смещение тени по горизонтали, второй — по вертикали. Третий и четвертый параметры — размытие и растяжение. Как видите, первые три мы не трогаем вообще. Размытие нам не нужно, потому что нам нужна резкая тень. Как видите, я прописывал четвертый параметр — растяжение. Он определяет, насколько тень будет больше элемента, к которому привязана.

По умолчанию все выглядит так — тень одинаковых размеров с элементом и лежит четко под ним. Если вы меняете растяжение, то тень начинает выступать за элемент. Именно так можно создавать рамки, абсолютно такие же, как свойством border . Ну а с пятым параметром, я думаю, все понятно — это цвет тени.

Как видите, я просто перечислил параметры для каждой новой тени через запятую. Я думаю, вы уже догадались, что таким же способом можно создать тройную рамку и т.д. Никаких ограничений тут нет. Собственно, как по мне вопрос закрыт, а если у вас есть какие-то вопросы, вы можете писать их в комментарии.

Минуточку вашего внимания: Все мы хотим размещать свои сайты на надежном хостинге. Я проанализировал сотни хостингов и нашел лучший - HostIQ В сети сотни положительных отзывов о нем, средняя оценка пользователей - 4.8 из 5. Пусть вашим сайтам будет хорошо.

Рамки имеют многообразное применение, например, как декоративный элемент или для отделения двух объектов. CSS предоставляет бесчисленное множество вариантов использования рамок.

Толщина рамки

Толщина рамки определяется свойством border-width , которое может иметь значения thin, medium и thick, или числовое значение в пикселах. На рисунке показана эта система:

Цвет рамки

Свойство border-color определяет цвет рамки. Значения - нормальные значения цвета, например: "#123456", "rgb(123,123,123)" или "yellow" .

Типы рамок

Существуют различные типы рамок. Ниже показаны восемь типов рамки и их интерпретация в Internet Explorer 5.5. Все примеры показаны цветом "gold" и толщиной "thick", но могут, естественно, выводиться другим цветом и толщиной.

Значения none или hidden могут использоваться, если вы не хотите отображать рамку.

Примеры определения рамок

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

,

,
    и

    Результат, может быть, не столь впечатляющ, но он демонстрирует некоторые возможности:

    H1 { border-width: thick; border-style: dotted; border-color: gold; } h2 { border-width: 20px; border-style: outset; border-color: red; } p { border-width: 1px; border-style: dashed; border-color: blue; } ul { border-width: thin; border-style: solid; border-color: orange; }

    Можно также установить специальные свойства для верхнего, нижнего, правого и левого края рамки. Вот как это делается:

    H1 { border-top-width: thick; border-top-style: solid; border-top-color: red; border-bottom-width: thick; border-bottom-style: solid; border-bottom-color: blue; border-right-width: thick; border-right-style: solid; border-right-color: green; border-left-width: thick; border-left-style: solid; border-left-color: orange; }

    Сокращённая запись

    Как и для многих других свойств, вы можете объединить несколько свойств в одно, используя слово border. Пример:

    P { border-width: 1px; border-style: solid; border-color: blue; }

    можно объединить в:

    P { border: 1px solid blue; }

    Резюме

    В этом уроке вы познакомились с безграничными возможностями CSS при использовании рамок.

    В следующем уроке мы рассмотрим, как определять размеры в боксовой модели - height и width.

    Для управления границей элемента применяется универсальное свойство border . Это свойство позволяет установить в одном объявлении толщину, стиль и цвет границы элемента.

    Эти три свойства (толщину, стиль и цвет границы) можно установить в одном объявлении. Вот пример:

    Границы в CSS

    Блок div с рамкой 3px красного цвета.

    Можно указать стиль границы только на одной стороны элемента. Для этого применяют свойства border-top (верхняя граница), border-right (правая граница), border-bottom (нижняя граница), border-left (левая граница).

    Границы в CSS

    Блок div с разными границами.

    В этом примере для каждой стороны блока задана своя толщина границы, стиль и цвет.

    Подумайте, как при помощи CSS можно создать такую фигуру:

    Значения границы - толщину, стиль и цвет - можно задать отдельно используя специальные свойства.

    • border-style - стиль границы.
    • border-width - ширина границы.
    • border-color - цвет границы.

    Рассмотрим каждое из значений по отдельности.

    Свойство border-style. Стиль границы.

    Свойство border-style устанавливает стиль рамки. В CSS, в отличии HTML, граница элемента может быть не только сплошной. Допустимы следующие значения для стиля границы:

    1. none - граница отсутствует (по умолчанию).
    2. solid - сплошная граница.
    3. double - двойная граница.
    4. dashed - пунктирная граница.
    5. dotted - граница из ряда точек.
    6. ridge - граница "гребень".
    7. groove - граница "бороздка".
    8. inset - вдавленная граница.
    9. outset - выдавленная граница.

    Примеры того, как они выглядят.

    граница отсутствует (none)


    сплошная граница (solid)


    двойная граница (double)


    граница из ряда точек (dotted)


    пунктирная граница (dashed)


    граница "бороздка" (groove)


    граница "гребень" (ridge)


    вдавленная граница (inset)


    выдавленная граница (outset)

    Кстати, если для рамки ridge задать цвет границы чёрный, то получится вот такой результат.

    Блок div с рамкой чёрного цвета и стиля ridge.

    Рамка выглядит как solid , но это потому что стиль ridge создаётся добавлением чёрного эффекта тени, а чёрный эффект на чёрной рамке не виден.

    При помощи свойства border-style стиль границы может быть задан не только для всех сторон блока. Есть возможность задавать несколько значений одному свойству border-style , в зависимости от числа значений стиль границы будет присвоен разному числу сторон блока. Можно задать одно, два, три и четыре значения. Давайте рассмотрим примеры для каждого случая.

    Одно значение (solid) - стиль границы установлен для всех сторон блока.


    Два значения (solid double) - первое значение установило стиль для верхней и нижней сторон, второе для боковой.


    Три значения (solid double dotted) - первое значение для верхней стороны, второе для боковых, стретье для нижней.


    Четыре значения (solid double dotted dashed) - каждое значение для одной стороны по часовой стрелке начиная с верхней.

    Свойство border-width. Толщина границы.

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

    Как и для свойства border-style , для свойства также можно задавать от одного до четырёх значений. Рассмотрим примеры для каждого случая.



    Код примера:

    Толщина границы в CSS

    Одно значение (2px) - толщина границы установлен для всех сторон блока.

    Два значения (1px 5px) - первое значение установило толщину для верхней и нижней сторон, второе для боковой.

    Три значения (1px 3px 5px) - первое значение для верхней стороны, второе для боковых, стретье для нижней.

    Четыре значения (1px 3px 5px 7px) - каждое значение для одной стороны по часовой стрелке начиная с верхней.

    Также для свойства border-width существуют значения в виде ключевых слов. Всего их три:

    • thin - тонкая граница;
    • medium - средняя толщина;
    • thick - толстая граница;

    Толщина границы: thin.


    Толщина границы: medium.


    Толщина границы: thick.

    Свойство border-color. Цвет границы.

    Для управления цветом границы используется средство border-color . Цвета для этого свойства можно задать используя любой способ, описанный в статье "Цвета в CSS ", а именно:

    • Шестнадцатеричная запись (#ff00aa ) цвета.
    • Формат RGB - rgb(255,12,110) . Формат RGBA для CSS3.
    • Форматы HSL и HSLA для CSS3.
    • Название цвета, например black (чёрный). Полный список названий цветов приведён в таблице названий цветов CSS .

    Свойство border-color также может иметь от одного до четырёх значений и обрабатывает их аналогично предыдущим свойствам.

    Одно значение (red).


    Два значения (red black).


    Три значения (red black yellow).


    Четыре значения (red black yellow blue).

    Теперь вернёмся к задаче, озвученной выше, и нарисуем фигуру:

    Вот код, который рисует такую фигуру, только побольше размером:

    Толщина границы в CSS

    Установка значений для сторон отдельно

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

    • border-top (верхняя граница)
    • border-right (правая граница)
    • border-bottom (нижняя граница)
    • border-left (левая граница)

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

    Параметры верхней границы (border-top ).

    • border-top-color - задаёт цвет верхней границы элемента.
    • border-top-width - задаёт толщину верхней границы элемента.
    • border-top-style - задаёт стиль верхней границы элемента.

    Параметры правой границы (border-right ).

    • border-right-color - задаёт цвет правой границы элемента.
    • border-right-width - задаёт толщину правой границы элемента.
    • border-right-style - задаёт стиль правой границы элемента.

    Параметры нижней границы (border-bottom ).

    • border-bottom-color - задаёт цвет нижней границы элемента.
    • border-bottom-width - задаёт толщину нижней границы элемента.
    • border-bottom-style - задаёт стиль нижней границы элемента.

    Параметры левой границы (border-left ).

    • border-left-color - задаёт цвет левой границы элемента.
    • border-left-width - задаёт толщину левой границы элемента.
    • border-left-style - задаёт стиль левой границы элемента.

    Пример использования этих свойств:

    Толщина границы в CSS

    В этом примере блоку div сначала заданы границы толщиной 3px и стилем solid для всех сторон. Затем:
    • переопределён цвет верхней границы при помощи свойства border-top-color в красный,
    • при помощи свойства border-right-width установлена толщина правой границы 10px,
    • при помощи свойства border-bottom-style стиль нижней границы переопределён как double,
    • при помощи свойства border-left-color левой границе установлен синий цвет.

    Свойство border-radius. Округление углов границы.

    Свойство border-radius предназначено для округления углов границ элемента. Это свойство появилось в CSS3 и корректно работает во всех современных браузерах, за исключением Internet Explorer 8 (и более старых версий).

    Значениями могут быть любые числа, используемые в CSS.

    Свойство border-radius: 15px.

    Если рамка блока не задана, то скругление происходит с фоном. Вот пример закругления блока без рамки, но с фоновым цветом:

    Свойство border-radius: 15px.

    Существуют свойства для скругленя каждого отдельно угла элемента. В этом примере использованы они все:

    Border-top-left-radius: 15px; border-top-right-radius: 0; border-bottom-right-radius: 15px; border-bottom-left-radius: 0;

    Свойство border-radius: 15px.

    Хотя этот код можно записать одним объявлением: border-radius : 15px 0 15px 0 . Дело в том, что для свойства border-radius можно задавать от одного до четырёх значений. В таблице ниже приведены правила, которые определяют такие объявления.

    Внимательно изучив эту таблицу можно понять, что самая короткая запись нужного стиля будет такой: border-radius : 15px 0 . Всего два значения.

    Немного практики

    Рисуем лимон средствами CSS.

    Вот код такого блока:

    Margin: 0 auto; /* Размещаем блок по центру */ width: 200px; height: 200px; background: #F5F240; border: 1px solid #F0D900; border-radius: 10px 150px 30px 150px;

    Мы уже рисовали фигуру:

    Теперь оставим от неё треугольник:

    Код треугольника такой:

    Margin: 0 auto; /* Размещаем блок по центру */ padding: 0px; width: 0px; height: 0; border: 30px solid white; border-bottom-color: red;

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

    Однако существует еще несколько методов для создания такого эффекта. Причем очевидное использование фонового изображения является весьма далеким от идеала.

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

    Метод 1: border и outline

    Данный метод работает только в тех браузерах, которые поддерживают свойство outline (все, кроме IE6/7). Вы добавляете элементу оба свойства border и outline .

    One { border: solid 6px #fff; outline: solid 6px #888; }

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

    Метод 2: псевдо элемент

    Данный метод требует абсолютного позиционирования рамки:

    Two { border: solid 6px #fff; position: relative; z-index: 1; } .two:before { content: ""; display: block; position: absolute; top: -12px; left: -12px; border: solid 6px #888; width: 312px; padding-bottom: 12px; min-height: 100%; z-index: 10; }

    Ключевыми моментами являются установка свойства z-index (чтобы псевдо элемент перекрывал содержание), позиционирование и значение min-height . Последнее свойство сохраняет эластичность рамки.

    Метод 3: тень

    Самый лучший метод, так как требуется только одна строчка кода с установками свойства box-shadow .

    Three { box-shadow: 0 0 0 6px #fff, 0 0 0 12px #888; }

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

    Как и свойство outline , box-shadow не влияет на соседние элементы и может перекрывать их. Поэтому надо установить поле для формирования внешнего вида композиции.

    Естественно, поддержка свойства box-shadow ограничена новыми браузерами.

    Метод 4: Дополнительный элемент div

    В данном методе используется внешний элемент

    для вывода двойной рамки. Единственный метод, который работает везде:

    Four { border: solid 6px #888; background: #fff; width: 312px; min-height: 312px; } .four div { width: 300px; min-height: 300px; background: #222; margin: 6px auto; overflow: hidden; }

    Внешний элемент имеет немного больший размер, что создает иллюзию двойной рамки.

    Метод 5: свойство border-image

    Еще одним новым методом является часто забываемое свойство CSS3 border-image:

    Five { border-width: 12px; -webkit-border-image: url(multiple-borders.gif) 12 12 12 12 repeat; -moz-border-image: url(multiple-borders.gif) 12 12 12 12 repeat; border-image: url(multiple-borders) 12 12 12 12 repeat; /* for Opera */ }

    Знаете другой метод?

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

    Влад Мержевич

    С помощью CSS можно добавить рамку к элементу несколькими способами. В основном, конечно же, применяется свойство border , как наиболее универсальное, а также outline и, как ни удивительно, box-shadow , основная задача которого - создание тени. Далее рассмотрим эти методы и их различия между собой.

    Свойство outline

    Самое простое свойство для создания рамок. Имеет те же параметры, что и border , но существенно отличается от него некоторыми деталями:

    • outline выводится вокруг элемента (border внутри);
    • outline не влияет на размеры элемента (border добавляется к ширине и высоте элемента);
    • outline можно установить только вокруг элемента целиком, но никак не на отдельных сторонах (border можно использовать для любой стороны или всех сразу);
    • на outline не действует радиус скругления, заданный свойством border-radius (на border действует).

    Возникает вопрос - в каких случаях нужен outline , когда его роль, несмотря на перечисленные отличия, вполне берёт на себя border ? Ситуаций не так и много, но они встречаются:

    • создание сложных разноцветных рамок;
    • добавление рамки к элементу при наведении на него курсора мыши;
    • сокрытие рамки, добавляемой браузером автоматически для некоторых элементов при получении фокуса;
    • для outline можно задать расстояние от края элемента до рамки с помощью свойства outline-offset , для создания .

    Разноцветные рамки

    Надо понимать, что outline ни в коей мере не заменяет border и вполне может существовать вместе с ним, как показано в примере 1.

    Пример 1. Создание рамки

    border и outline

    В данном примере вокруг элемента добавляется чёрная рамка, которая отделена от фона белой каймой (рис. 1).

    Рис. 1. Рамка вокруг элемента

    Рамка при использовании:hover

    При добавлении рамки через border происходит увеличение ширины элемента, что довольно заметно при сочетании border и псевдокласса :hover . Есть два способа, как это «победить». Самое простое - заменить border на outline , которое, как мы знаем, не оказывает влияния на размеры элемента (пример 2).

    Пример 2. Рамка при наведении

    outline

    outline не всегда годится, хотя бы потому, что на него скругление уголков не действует. Здесь подойдёт второй метод - добавляем невидимую рамку или рамку, совпадающую с цветом фона, а затем меняем её параметры при наведении (пример 3). Тогда никакого смещения элемента происходить не будет, поскольку рамка изначально уже есть. Но всегда помним, что ширина элемента при этом складывается из значений width , border слева и border справа. Аналогично обстоит и с высотой.

    Пример 3. Рамка при наведении

    border

    Рамка вокруг полей формы

    В некоторых браузерах (Chrome, Safari, последние версии Opera) вокруг полей формы при получении ими фокуса отображается небольшая цветная рамка (рис. 2). Чтобы её убрать, достаточно в стилях добавить к свойству outline значение none , как показано в примере 4.

    Рис. 2. Рамка вокруг полей

    Пример 4. Убираем рамку

    input

    Рамки через box-shadow

    Хотя свойство box-shadow предназначено для добавления тени вокруг элемента, с его помощью можно и создавать рамки, причём такие, которые невозможно сделать через border или outline . Всё благодаря тому, что число теней может быть неограниченным, параметры которых перечисляются через запятую.

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

    В примере 4 показано добавление двух рамок и одной границы справа с помощью одного свойства box-shadow .

    Пример 4. Использование box-shadow

    box-shadow

    Результат данного примера показан на рис. 3.

    Рис. 3. Рамки, созданные свойством box-shadow