—»     —»   Разрабатываем календарь с помощью jQuery и CSS3
  Раздел: Руководства   Нет комментариев  

Разрабатываем календарь с помощью jQuery и CSS3



В данном руководстве мы собираемся разработать календарь на jQuery и CSS3, который вы можете видеть в проекте Futurico UI Pro, разработанным Владимиром Кудиновым. Для этого мы воспользуемся CSS (для всего оформления) и jQuery/jQuery UI (для функционала). Из jQuery UI мы будем использовать только скрипт Datepicker. Так что, вам не придется скачивать все компоненты, доступные в jQuery UI, и размер файла будет меньше.

Разрабатываем календарь с помощью jQuery и CSS3

Сложность: средняя Необходимое время: 30 минут

Этап 1 – HTML-разметка

Для создания календаря нам потребуется лишь добавить div с id.

<div id="calendar"></div>

Затем, перед закрывающим тэгом body, нам нужно добавить скрипты jQuery и jQuery UI.

Нам также необходимо вызывать datepicker, поэтому вам нужно использовать тот же id, который вы использовали при создании div. Далее мы добавим некоторые опции: параметр inline сделает календарь видимым, поэтому нам не нужно будет кликать по кнопке или элементу ввода. Для того чтобы сделать «Monday» (понедельник) первым днем календаря, нужно выставить его на 1; «show other months» добавить другие дни месяца в очередь, чтобы заполнить таблицу. Для более подробной информации о всех опциях, ознакомьтесь с документацией.

<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.1/jquery.min.js"></script>
<script src="js/jquery-ui-datepicker.min.js"></script>
<script>
$('#calendar').datepicker({
inline: true,
firstDay: 1,
showOtherMonths: true,
dayNamesMin: ['Sun', 'Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat']
});
</script>

Разрабатываем календарь с помощью jQuery и CSS3

Этап 2 – Контейнер

Давайте начнем с того, что уберем все поля, отступы, границы и т.д.

.ui-datepicker,
.ui-datepicker table,
.ui-datepicker tr,
.ui-datepicker td,
.ui-datepicker th {
margin: 0;
padding: 0;
border: none;
border-spacing: 0;
}

Затем оформим контейнер календаря. Мы добавим цвет фона, закругленные углы и тени. Мы также изменим шрифт на Tahoma и его размер.

.ui-datepicker {
display: none;
width: 294px;
padding: 35px;
cursor: default;

text-transform: uppercase;
font-family: Tahoma;
font-size: 12px;

background: #141517;

-webkit-border-radius: 3px;
-moz-border-radius: 3px;
border-radius: 3px;

-webkit-box-shadow: 0px 1px 1px rgba(255,255,255, .1), inset 0px 1px 1px rgb(0,0,0);
-moz-box-shadow: 0px 1px 1px rgba(255,255,255, .1), inset 0px 1px 1px rgb(0,0,0);
box-shadow: 0px 1px 1px rgba(255,255,255, .1), inset 0px 1px 1px rgb(0,0,0);
}

Разрабатываем календарь с помощью jQuery и CSS3

Этап 3 – Шапка

Для того чтобы оформить шапку календаря (месяц и год), мы изменим цвет текста, добавим границу по нижнему краю и некоторые основные стили.

.ui-datepicker-header {
position: relative;
padding-bottom: 10px;
border-bottom: 1px solid #d6d6d6;
}

.ui-datepicker-title { text-align: center; }

.ui-datepicker-month {
position: relative;
padding-right: 15px;
color: #565656;
}

.ui-datepicker-year {
padding-left: 8px;
color: #a8a8a8;
}

Чтобы добавить зеленый круг, мы воспользуемся псевдо-селектором :before. Это позволит нам вставить контент до элемента «month», а затем мы оформим его и расположим так, как нам нужно.

.ui-datepicker-month:before {
display: block;
position: absolute;
top: 5px;
right: 0;
width: 5px;
height: 5px;
content: '';

background: #a5cd4e;
background: -moz-linear-gradient(top, #a5cd4e 0%, #6b8f1a 100%);
background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#a5cd4e), color-stop(100%,#6b8f1a));
background: -webkit-linear-gradient(top, #a5cd4e 0%,#6b8f1a 100%);
background: -o-linear-gradient(top, #a5cd4e 0%,#6b8f1a 100%);
background: -ms-linear-gradient(top, #a5cd4e 0%,#6b8f1a 100%);
background: linear-gradient(top, #a5cd4e 0%,#6b8f1a 100%);

-webkit-border-radius: 5px;
-moz-border-radius: 5px;
border-radius: 5px;
}

Разрабатываем календарь с помощью jQuery и CSS3

Этап 4 – Предыдущий и следующий месяц

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

.ui-datepicker-prev,
.ui-datepicker-next {
position: absolute;
top: -2px;
padding: 5px;
cursor: pointer;
}

.ui-datepicker-prev {
left: 0;
padding-left: 0;
}

.ui-datepicker-next {
right: 0;
padding-right: 0;
}

.ui-datepicker-prev span,
.ui-datepicker-next span{
display: block;
width: 5px;
height: 10px;
text-indent: -9999px;

background-image: url(../img/arrows.png);
}

.ui-datepicker-prev span { background-position: 0px 0px; }

.ui-datepicker-next span { background-position: -5px 0px; }

.ui-datepicker-prev-hover span { background-position: 0px -10px; }

.ui-datepicker-next-hover span { background-position: -5px -10px; }

Разрабатываем календарь с помощью jQuery и CSS3

Этап 5 – Оформление календаря

Для оформления дней недели мы добавим отступы с верхней и нижней стороны, а также изменим цвет.

.ui-datepicker-calendar th {
padding-top: 15px;
padding-bottom: 10px;

text-align: center;
font-weight: normal;
color: #a8a8a8;
}

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

.ui-datepicker-calendar td {
padding: 0 7px;

text-align: center;
line-height: 26px;
}

.ui-datepicker-calendar .ui-state-default {
display: block;
width: 26px;
outline: none;

text-decoration: none;
color: #a8a8a8;

border: 1px solid transparent;
}

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

.ui-datepicker-calendar .ui-state-active {
color: #6a9113;
border: 1px solid #6a9113;
}

.ui-datepicker-other-month .ui-state-default { color: #565656; }

Разрабатываем календарь с помощью jQuery и CSS3

В завершение

Мы закончили работу над календарем. Не забудьте поделиться своими впечатлениями или советами в разделе комментариев.

* Смотреть демо
Внимание! У вас нет прав для просмотра скрытого текста.
Обнаружили ошибку или мёртвую ссылку?
Выделите проблемный фрагмент мышкой и нажмите CTRL+ENTER.
В появившемся окне опишите проблему и отправьте уведомление Администрации ресурса.
Нужна органическая вечная ссылка из данной статьи? Постовой?
Подробности здесь
Вам понравился материал? Поблагодарить легко!
Будем весьма признательны, если поделитесь этой статьей в социальных сетях:

Ключевые тэги: jQuery, CSS, календарь
Опубликовал Design FactoRy   Прочитано (раз): 8518   |   Нет комментариев
Источник материала / оригинал статьи   Распечатать
Другие статьи и новости по теме:
Добавление комментария
Уважаемые пользователи!
При добавлении комментариев на сайт Вам следует учитывать следующее - все комментарии проверяются Администрацией на предмет отсутствия спама. При обнаружении признаков спама, в оставленном Вами комментарии, сам комментарий будет незамедлительно удалён, а Ваш IP-адрес будет забанен без предупреждения! Учётные записи пользователей, рассылающих спам, блокируются/удаляются без права последующего восстановления.

С уважением, Администрация сайта.
* = поля обязательны к заполнению
Полужирный Наклонный текст Подчеркнутый текст Зачеркнутый текст | Выравнивание по левому краю По центру Выравнивание по правому краю | Вставка смайликов Выбор цвета | Скрытый текст Вставка цитаты Преобразовать выбранный текст из транслитерации в кириллицу Вставка спойлера
Вопрос : Назовите месяц January по-русски
Подтверждение кода безопасности :

Включите эту картинку для отображения кода безопасности
обновить, если не виден код


Популярные публикации


















Свежие шаблоны сайтов каждый день
С миру по нитке
«    Ноябрь 2017    »
ПнВтСрЧтПтСбВс
 12345
6789101112
13141516171819
20212223242526
27282930