传统的日历是在一张页面划分出几个格子.作为一个网页设计师,你有权利用表格来做出效果,我也不会说你错了.
那么做为一个标准的WEB设计师来说,遵守WEB的标准好处是不言而语的.那么我们来看下如何使用CSS来做出一个有弹性的日历表出来--为什么说是有弹性的,因为日历的大小可以随着浏览器自动调整.
最终效果演示
点击这里下载
三个有序列表(ol)
我们来回想一下日历的格式,显然一个月的日历并不是单一的有序列表,而是有三个.为什么说是有三个,别急我们往下看.我们在看日历表的时候,是不是会看到每个月的一号不一定是从星期一开始,最后一号是以星期天结束的.因此在每个月的日期前后各加一个有序例表.(现在知道了吧,不知道的面避去^_^)
==========================
<ol class="calendar" start="6">
<li id="lastmonth"> <ol start="29"> <li>29</li> <li>30</li> </ol> </li>
<li id="thismonth"> <ol> <li>1</li> <li>2</li> <li>3</li> <li>4</li> <li>5</li> <li>6</li> <li>7</li> <li>8</li> <li>9</li> <li>10</li> <li>11</li> <li>12</li> <li>13</li> <li>14</li> <li>15</li> <li>16</li> <li>17</li> <li>18</li> <li>19</li> <li>20</li> <li>21</li> <li>22</li> <li>23</li> <li>24</li> <li>25</li> <li>26</li> <li>27</li> <li>28</li> <li>29</li> <li>30</li> <li>31</li> </ol> </li>
<li id="nextmonth"> <ol> <li>1</li> <li>2</li> </ol> </li>
</ol> ==========================
下面是CSS样式表
======================== /* * CSS Calendar * Tim Wright * Chris Coyier -----------------------------*/
* {margin:0;padding:0;} body {font:1em/1.4 Verdana, Arial, Helvetica, sans-serif; background: url(images/bg.jpg) top center no-repeat #545454;} body * {display:inline;} ol.calendar {width:52em;margin:0 auto;display:block; min-height: 200px; background: url(images/tl.png) top left no-repeat; padding: 12px 0 0 20px;} li {list-style:none;} p.link {text-align:center;display: block;} h1 {display: block; width: 200px;height:76px; background:url(images/july.png);text-indent:-9999px; margin: 15px auto; }
/* * Day styles -------------------------*/ li li {width:6em;height:6em;float:left;margin:.2em; padding:.2em;overflow:auto; background: url(images/day-bg.png) bottom right no-repeat; }
/* * Day content (UL/OL & P) -------------------------*/ li li p {font-size:.7em;display:block;} li li ol {width:auto;} li li ul li, li li ol li {font-size:.7em;display:block;height:auto;width:auto; background: none; margin:0;padding:.2em 0;float:none;}
/* * Holiday class -------------------------*/ li li.holiday { }
/* * Inactive months -------------------------*/ li#lastmonth li, li#nextmonth li { background: url(images/day-bg-inactive.png);} =========================
|