Красивые рамки в CSS3
Создание рамок в HTML и CSS доступно с самого появления данных языков. Наверняка вы знакомы со сплошными рамками, рамками с точечными линиями и так далее. Но CSS3 расширяет возможности работы с рамками - теперь можно использовать изображения для создания более привлекательных рамок, например, таких:
Синтаксис и поддержка браузерами
Рамка с изображением в CSS3 определяется следующим образом:
border-image: [источник_изображения] [нарезка_изображения] [ширина] [начало] [повторение];
Описанный выше синтаксис является официальной версией W3C, которая поддерживается только в Chrome, а Opera, Firefox, и Safari требуют префиксов (-o-
, -moz-
, -webkit-
), а Internet Explorer совсем не поддерживает данное свойство.
К тому же, значения [ширина]
и [начало]
в свойстве border-image
НЕ ПОДДЕРЖИВАЮТСЯ ни в одном браузер. Однако, ширину можно задать с помощью свойства border-width
.
Итак, в настоящий момент доступны только значения [источник_изображения]
, [нарезка_изображения]
и [повтороение]
.
border-image: [image source] [slice] [repeat];
Нарезка изображения
Прежде, чем мы продолжим, нужно разобраться с “нарезкой изображения”, так как это новое веяние в определении свойств. Нарезка изображения определяет разрезы на исходном изображении, которые проводятся соответственно сверху, справа, снизу и слева от границ изображения и разделяют его на девять частей, как показано на следующем рисунке.
Как видно на рисунке, секции 1, 3, 7 и 9 будут использоваться для углов рамки, а секции 2, 4, 6 и 8 - для сторон рамки (следует убедиться, что секции сторон можно растягивать или повторять без визуальных искажений).
Значение для нарезки можно задавать в пикселях или процентах.
Создаем рамку для фотографии
Теперь сделаем рамку для реального примера.
Мы будем использовать свойство border-image
для формирования фоторамки с помощью ниже приведенного изображения. Мы тщательно измерили его чтобы нарезать правильно - углы, растяжение и повторы для сторон будут выполняться без искажений.
Также для демонстрации используется следующая фотография:
Разметка
Разметка очень простая:
<div class="wrapper"> <img src="/path/photo.jpg"> </div>
Стили
А теперь сделаем рамку с помощью свойства border-image
.
Если посмотреть на выше приведенную картинку, то можно заметить, что наше изображение имеет ширину 180px. Значение делится на шесть, то есть каждая секция будет шириной 30px (нарезка изображения).
Если вы используете значение в px, то единицы можно не указывать, а для процентов придется ставить рядом с цифрами символ %.
Для повтора секции используется значение repeat
. В качестве альтернативы можно использовать значение stretch
для растягивания секции на установленную ширину.
img { border-image:url("images/frame.png") 30 repeat; -o-border-image:url("images/frame.png") 30 repeat; -moz-border-image:url("images/frame.png") 30 repeat; -webkit-border-image:url("images/frame.png") 30 repeat; border-width: 30px; }
В дополнение мы также разместим изображение в центре окна браузера и добавим текстуру к фону документа.
html { background: url('images/lightpaperfibers.png'); } .wrapper { margin: 20px auto; height: 476px; width: 675px; text-align: center; }
И все. Смотрим демонстрационную страницу.
Источник: http://feedproxy.google.com/~r/ruseller/CdHX/~3/v5Cbc2qvGZU/lessons.php
Дайджест новых статей по интернет-маркетингу на ваш email
Новые статьи и публикации
- 2024-04-17 » 23 сервиса для эффективного экспресс-аудита любого сайта
- 2024-04-08 » Яндекс переходит на новую версию Wordstat
- 2024-04-08 » Яндекс интегрировал в свой облачный сервис эмпатичную нейросеть
- 2024-04-08 » Новая версия нейросети Claude превзошла по мощности аналоги Google и OpenAI
- 2024-04-08 » Как пользоваться GPT 4 и Claude бесплатно и без VPN
- 2024-03-13 » Стратегии SEO на 2024 год
- 2024-03-13 » Как использовать анимацию с помощью JavaScript-библиотеки GSAP
- 2024-03-13 » Использование GSAP 3 для веб-анимации
- 2024-03-13 » Cогласование топографической съёмки с эксплуатирующими организациями
- 2024-02-19 » Теряются лиды? Как настроить сквозную аналитику
- 2024-02-17 » Мерч и IT: на что обратить внимание в 2024 году
- 2024-02-16 » Копируем с RSync: основные примеры синхронизации файлов
- 2024-02-15 » Лучшие noCode AI платформы для создания диалоговых ботов
- 2024-02-14 » Факторы ранжирования Google 2024 — исследование Semrush
- 2024-02-12 » Перенос сайта на другой хостинг
- 2024-02-05 » В России сформирован реестр хостинг-провайдеров
- 2024-02-04 » Использование SSH для подключения к удаленному серверу Ubuntu
- 2024-02-03 » Подключаемся к серверу за NAT при помощи туннеля SSH. Простая и понятная инструкция
- 2024-02-02 » Настройка CI/CD для Gitlab-репозитория: схемы и гайд по шагам
- 2024-02-01 » GitLab CI Pipeline. Запуск сценария через SSH на удаленном сервере
- 2024-01-29 » Introduction to GitLab’s CI/CD for Continuous Deployments
- 2024-01-26 » Настройка GitLab CI/CD
- 2024-01-25 » Установка shell gitlab runner
- 2024-01-25 » Установка и регистрация gitlab-runner в docker контейнере
- 2024-01-25 » Переменные Gitlab-Ci
- 2024-01-25 » Настройка CI/CD в GitLab для синхронизации проекта с веб-серверами
- 2024-01-25 » Копирование файлов scp
- 2024-01-21 » Бездепозитные бонусы от казино: обзор условий и правил использования
- 2024-01-18 » Современная обработка ошибок в PHP
- 2024-01-18 » Пример шаблона проектирования MVC в PHP
Постановка целей, приближение к ним день за днем и, наконец, их достижение — это и есть ключ к счастью Трейси Брайан - - современный американский профессиональный лектор-преподаватель |
Мы создаем сайты, которые работают! Профессионально обслуживаем и продвигаем их , а также по всей России и ближнему зарубежью с 2006 года!
Как мы работаем
Заявка
Позвоните или оставьте заявку на сайте.
Консультация
Обсуждаем что именно Вам нужно и помогаем определить как это лучше сделать!
Договор
Заключаем договор на оказание услуг, в котором прописаны условия и обязанности обеих сторон.
Выполнение работ
Непосредственно оказание требующихся услуг и работ по вашему заданию.
Поддержка
Сдача выполненых работ, последующие корректировки и поддержка при необходимости.