sonyps4.ru

Закругленные углы с помощью CSS. Скруглённые уголки

Большинство программистов при фразе «закругленные углы» начинает бить нервная дрожь. Это конечно, дизайнерское решение. Иногда бывает вполне прилично смотрится, но рисуя закругленные углы, многие дизайнеры раньше не задумывались насколько увеличивается html код страницы.

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

Если вспомнить что из себя представляли старые способы:

  1. Использование таблиц.В худшем случае блок мог раздвигаться не только вертикально, но и горизонтально, тогда мы получали таблицу с 9 ячейками, для каждой из которых задавался фон: отрезанная часть соответствующей области рамки. И было просто прекрасно, если внутренний фон не был градиентным или снаружи рамки не было теней при неоднородном фоне страницы.
  2. Использование кучи div блоков. Тоже самое, при горизонтальном и вертикальном масштабировании блока нужно было использовать, как минимум 8 div-ов вложенных друг в друга.
  3. Так же были и более экзотичные способы. 🙂

Скругление углов средствами CSS3

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

Имеем html код на странице:

Наш текст

Код CSS, который и закругляет наши углы:

Div.block { display: block; margin: 5px; padding: 0px; border: 1px solid #989898; -moz-border-radius: 5px; -webkit-border-radius: 5px; border-radius: 5px; background-color: #FFF; }

Из приведенного выше кода за закругление отвечают только строчки:

Moz-border-radius: 5px; -webkit-border-radius: 5px; border-radius: 5px;

На самом деле, привел пример самый простой, где все углы одинакового радиуса. Хоть и можно в браузерах FireFox и Webkit (Safari, Chrome) настраивать разные радиусы по конкретным углам или даже переменный радиус одного угла, как всегда Opera и IE - впереди планеты всей, точнее сзади. В этих браузерах эти функции не работают. Посему, думаю стоит возвращаться к этому вопросу, когда везде эта функция будет работать в полной мере.

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

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

Код Описание Вид
div { border-radius: 10px; } Радиус скругления для всех уголков сразу.
div { border-radius: 0 10px; } Первое значение устанавливает радиус левого верхнего и правого нижнего уголка, второе значение — для правого верхнего и левого нижнего.
div { border-radius: 20px 10px 0; } Первое значение задаёт радиус левого верхнего уголка, второе — одновременно правого верхнего и левого нижнего, а третье значение — правого нижнего.
div { border-radius: 20px 10px 5px 0; } Последовательно устанавливает радиус левого верхнего уголка, правого верхнего, правого нижнего и левого нижнего.

В примере 1 показано создание блока со скруглёнными уголками.

Пример 1. Уголки у блока

HTML5 CSS3 IE 9+ Cr Op Sa Fx

Радиус

Меня - супплетивная форма винительного падежа от я.

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

Рис. 1. Блок со скруглёнными уголками

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

Пример 2. Круглая кнопка

HTML5 CSS3 IE 9+ Cr Op Sa Fx

Кнопка

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

Рис. 2. Круглая кнопка

В браузере Opera скругление к

Загрузка...