如何使用 jQuery 和 CSS3 創(chuàng)建一個(gè)日歷控件
這個(gè)教程將教你如何使用 jQuery 和 CSS3 來(lái)創(chuàng)建一個(gè)絢麗的日歷控件。我們將使用 CSS 來(lái)做樣式,使用 jQuery 和 jQuery UI 來(lái)做功能。我們將只使用 jQuery UI 中的 “Datepicker” 腳本,所以你不需要下載所有的組件,可以讓你的文件更小。
***步 - HTML 代碼
我們只需要一行 HTML 代碼,請(qǐng)注意這里的 id 屬性:
- <div id="calendar"></div>
在 body 標(biāo)簽之前,我們添加 jQuery 代碼。這里我們需要調(diào)用“datepicker”,你需要上面定義的 div 的 id 屬性。我們?cè)谶@里添加了一些選項(xiàng):
inline - 讓日歷默認(rèn)可見(jiàn),不需要點(diǎn)擊或者輸入控件
firstDay - 設(shè)置 Monday 為一周的開(kāi)始
showOtherMonths - 在表格中填充其他月份的日期以充滿表格
更多選項(xiàng)的解釋,請(qǐng)查看文檔。
- <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>
現(xiàn)在日歷看起來(lái)是這樣的:
#p#
第二步 - 容器
我們首先來(lái)移除所有的空白,填充,邊框等等:
- .ui-datepicker,
- .ui-datepicker table,
- .ui-datepicker tr,
- .ui-datepicker td,
- .ui-datepicker th {
- margin: 0;
- padding: 0;
- border: none;
- border-spacing: 0;
- }
下面來(lái)讓這個(gè)日歷好看一點(diǎn),添加背景顏色,圓角,陰影,字體等等:
- .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);
- }
現(xiàn)在這個(gè)日歷看起來(lái)是這樣的:
#p#
第三步 - 頭部
我們將更改日歷頭部(月份、年份)的顏色,并添加邊框,還有一些基本樣式:
- .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 pseudo selector”來(lái)添加綠色的圈圈。這可以讓我們?cè)?month 元素之前插入內(nèi)容,然后我們就可以格式化并設(shè)置內(nèi)容的位置:
- .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;
- }
現(xiàn)在日歷控件看起來(lái)是這樣的:
#p#
第四步 - Prev 和 Next 按鈕
我們將使用背景圖片來(lái)格式化 next 和 previous 箭頭,我們將把 previous 放在左邊,next 放在右邊:
- .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; }
現(xiàn)在日歷看起來(lái)是這樣的:
#p#
第五步 - 日歷樣式
我們將給 天 和 周 添加頂部和底部的填充并修改顏色:
- .ui-datepicker-calendar th {
- padding-top: 15px;
- padding-bottom: 10px;
- text-align: center;
- font-weight: normal;
- color: #a8a8a8;
- }
下面來(lái)給“days grid"添加填充,修改顏色,并給每一個(gè)數(shù)字添加一個(gè)透明的邊框。這是很必要的,因?yàn)槲覀円o選中的數(shù)字添加邊框,為了防止頁(yè)面跳動(dòng),我們預(yù)先給所有的數(shù)字都添加一個(gè)透明的邊框:
- .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;
- }
對(duì)于當(dāng)前選中的日期,我們要更改邊框和文字的顏色為綠色。對(duì)于其他月份的日期,我們要修改為更暗的顏色:
- .ui-datepicker-calendar .ui-state-active {
- color: #6a9113;
- border: 1px solid #6a9113;
- }
- .ui-datepicker-other-month .ui-state-default { color: #565656; }
就這樣我們的日歷做完了,下圖是最終效果:
你可以點(diǎn)擊 這里 查看這個(gè)日歷的demo。