Книга: HTML 5, CSS 3 и Web 2.0. Разработка современных Web-сайтов
Представление для нашего Web-сайта, часть 6
Представление для нашего Web-сайта, часть 6
Что ж, отступы и рамки мы создавать научились. По крайней мере, теоретически. Настала пора применить полученные знания на практике.
Прежде всего, сделаем отступы между контейнерами, формирующими дизайн наших Web-страниц, и между границами этих контейнеров и их содержимым.
— Внешний отступ между краями окна Web-обозревателя и содержимым Web- страницы равен нулю. Пусть пространство в окне Web-обозревателя используется максимально полно.
НА ЗАМЕТКУ
По умолчанию каждый Web-обозреватель создает свои отступы между краями своего окна и содержимым Web-страницы.
— Внутренние отступы в контейнере с заголовком Web-сайта (cheader) слева и справа — по 20 пикселов. Нам придется отодвинуть текст заголовка от краев окна Web-обозревателя, иначе заголовок будет выглядеть некрасиво.
— Внешний отступ между контейнерами с полосой навигации (cnavbar) и с основным содержимым (cmain) — 10 пикселов.
— Внутренние отступы у контейнера с основным содержимым (cmain) со всех сторон — по 5 пикселов.
— Внутренний отступ у контейнера с основным содержимым (cmain) сверху — 10 пикселов. Так мы отделим его от контейнеров cnavbar и cmain.
— Внутренние отступы в контейнере со сведениями об авторских правах (ccopyright) слева и справа — по 20 пикселов. Текст сведений об авторских правах также следует отодвинуть от краев окна Web-обозревателя.
Приведенные значения отступов получены автором в результате экспериментов. Вы можете задать другие.
Теперь разделим все четыре контейнера рамками.
— Контейнер cheader получит рамку с одной нижней стороной.
— Контейнер cmain — рамку с одной левой стороной.
— Контейнер ccopyright — рамку с одной верхней стороной.
Рамки мы сделаем тонкими и точечными. В качестве цвета зададим для них #B1BEC6 (светло-синий).
В листинге 11.3 приведен исправленный фрагмент CSS-кода таблицы стилей main.css, реализующий выбранные нами параметры отступов и рамок.
Листинг 11.3
BODY { color: #3B4043; background-color: #F8F8F8; font-family: Verdana, Arial, sans-serif; margin: 0px }
.
#cheader { width: 1010px; padding: 0 20px; border-bottom: thin dotted #B1BEC6 }
#cnavbar { width: 250px; height: 570px; float: left; margin-right: 10px }
#cmain { width: 760px; height: 570px; float: left; overflow: auto; padding: 5px; border-left: thin dotted #B1BEC6 }
#ccopyright { width: 1010px; clear: both; padding: 10px 20px 0px 20px; border-top: thin dotted #B1BEC6 }
Давайте разберем его.
Чтобы убрать отступ между границами окна Web-обозревателя и содержимым Web-страницы, мы использовали атрибут стиля margin. Его мы поместили в стиль переопределения тега <BODY> и дали ему значение 0 пикселов:
BODY { color: #3B4043; background-color: #F8F8F8; font-family: Verdana, Arial, sans-serif; margin: 0px }
В именованном стиле cheader, привязанном к одноименному контейнеру, мы задали внутренние отступы слева и справа, равные 20 пикселам, и рамку с одной только нижней стороной. Эта рамка отделит данный контейнер от нижележащих:
#cheader { width: 1010px; padding: 0 20px; border-bottom: thin dotted #B1BEC6 }
Кроме того, мы задали в качестве ширины этого контейнера абсолютное значение.
Вспомним: при выводе на экран контейнера с относительной шириной Web- обозреватель сначала вычислит абсолютное значение его ширины, а потом добавит к нему величину отступов. В результате чего контейнер станет шире, чем окно Web-обозревателя, и в окне появятся полосы прокрутки, что нам совсем не нужно. Поэтому для ширины контейнера лучше задать абсолютное значение, подобрав его так, чтобы контейнер гарантированно поместился в окно Web-обозревателя по ширине.
В именованном стиле cnavbar мы указали внешний отступ справа 10 пикселов — он визуально отделит контейнер cnavbar от контейнера cmain:
#cnavbar { width: 250px; height: 570px; float: left; margin-right: 10px }
В именованном стиле cmain мы задали внутренние отступы и рамку с одной левой стороной — она отделит контейнер cmain от контейнера cnavbar:
#cmain { width: 760px; height: 570px; float: left; overflow: auto; padding: 5px; border-left: thin dotted #B1BEC6 }
В именованном стиле ccopyright мы задаем отступы слева и справа по 20 пикселов, а сверху — 10 пикселов. Кроме того, мы создаем рамку с одной верхней стороной, которая отделит контейнер ccopyright от вышерасположенных "соседей":
#ccopyright { width: 1010px; clear: both; padding: 10px 20px 0px 20px; border-top: thin dotted #B1BEC6 }
Вот и все. Сохраним таблицу стилей main.css и откроем Web-страницу index.htm в Web-обозревателе. Автор не будет приводить здесь иллюстрацию, т. к. созданные нами тонкие рамки на ней практически незаметны. Но на экране компьютера они выглядят весьма эффектно.
Посмотрим теперь на полосу навигации. Невыразительные гиперссылки скучились в верхней части контейнера cnavbar, просто жалко на них смотреть!.. Давайте их сдвинем влево, немного "разредим", создав отступы, и заодно заключим каждую из них в рамки.
Как мы помним, наша полоса навигации представляет собой список, а отдельные ее гиперссылки — пункты данного списка.
Вот необходимые изменения:
— Список, формирующий полосу гиперссылок, сдвинуть влево на 30 пикселов. Так мы ликвидируем образовавшееся после удаления маркеров свободное пространство слева, которое смотрится некрасиво.
— Внешние отступы у пунктов списка сверху и снизу — 10 пикселов. Так мы отделим гиперссылки друг от друга.
— Рамка пунктов списка — тонкая, сплошная, цвет #B1BEC6.
— Внутренние отступы пунктов списка: сверху и снизу — по 5 пикселов, слева и справа — по 10 пикселов. Так мы отделим текст пунктов от рамок.
Осталось только соответственно исправить CSS-код таблицы стилей main.css (листинг 11.4).
Листинг 11.4
#navbar { font-family: Arial, sans-serif; font-size: 14pt; text-transform: uppercase; list-style-type: none; margin-left: -30px }
#navbar LI { padding: 5px 10px; margin: 10px 0px; border: thin solid #B1BEC6 }
Рассмотрим их подробнее.
В именованный стиль navbar, привязанный к тегу списка, который формирует полосу навигации, мы добавили отступ слева, равный –30 пикселов. Благодаря этому список сместится влево, заполняя пустое пространство:
#navbar { font-family: Arial, sans-serif; font-size: 14pt; text-transform: uppercase; list-style-type: none; margin-left: -30px }
Вновь созданный комбинированный стиль создаст у пунктов списка, формирующего полосу навигации, рамку и задаст соответствующие отступы:
#navbar LI { padding: 5px 10px; margin: 10px 0px; border: thin solid #B1BEC6 }
Сохраним исправленную таблицу стилей и обновим открытую в Web-обозревателе Web-страницу index.htm, нажав клавишу <F5>. Стало значительно лучше, не так ли (рис. 11.1)?
Рис. 11.1. Полоса навигации на Web-странице index.htm после применения к ней стилей
Теперь немного отвлечемся от CSS и займемся HTML. Есть у наших Web-страничек изъян, непростительный для хорошего Web-дизайнера.
- ГЛАВА 07 ГЕРОИ НАШЕГО ПОВЕСТВОВАНИЯ
- Ограниченность нашего сознания
- Представление для нашего Web-сайта, часть 1
- Представление для нашего Web-сайта, часть 2
- ГЛАВА 10. Контейнерный Web-дизайн
- Представление для нашего Web-сайта, часть 4
- Представление для нашего Web-сайта, часть 3
- Представление для нашего Web-сайта, часть 7
- Представление для нашего Web-сайта, часть 5
- Представление для нашего Web-сайта, часть 8