如何用CSS定义表格与模拟表格

80酷酷网    80kuku.com

  css

在这里~首先要说明的~我不是推荐大家使用表格布局,而是跟大家说明在显示大批量的数据时~还有表格可以用,而用DIV可以模拟出绝大部分以前的表格布局跟数据显示,在后面会讲些代替表格的显示方式.同时,因为找详细的中文介绍.英文的水平又有限.看W3C那介绍~有些地方可能理解错误,如果有发现的朋友请帮忙指出.

[1]表格应用
1表格的基本标签
2分析表格的基本标签
3基本演示
[2]层模拟表格
1模拟前的建议
2两列多行的数据显示
3三列多行的数据显示

表格应用

1、表格的基本标签:

TABLE { display: table }
TR { display: table-row }
THEAD { display: table-header-group }
TBODY { display: table-row-group }
TFOOT { display: table-footer-group }
COL { display: table-column }
COLGROUP { display: table-column-group }
TD, TH { display: table-cell }
CAPTION { display: table-caption }

虽然CSS2里可以把别的标签定义得跟table的一样
可是 IE 不支持 所以~应该用表格的地方还是用表格好?
说到表格,自己悄悄的BS一下FF 虽然很不情愿.

2、分析表格的基本标签:

table
table元素定义一个表格的开始
tr
表格中的行
THEAD
表头
TBODY
表的主体
TFOOT
表底
COL
指定基于列的表格默认属性,嵌套的 COL 属性将覆盖 COLGROUP 属性
COLGROUP
指定表格中一列或一组列的默认属性。
TD, TH
单元格
CAPTION
表名

3、基本演示:

不想过多的讲表格,这是一个比较完整的表格的演示,同时继承XHTML的思想,结构与表现的分离,不再为元素的属性做演示

<table class="tab">
  <caption>表名</caption>
  <colgroup class="g1" span="3" >
    <col class="c1" />
    <col class="c2"/>
    <col class="c3"/>
  </colgroup>
  <colgroup class="g2" span="1" >
  </colgroup>
  <thead>
    <tr>
      <th>表头1</th>
      <th>表头2</th>
      <th>表头3</th>
      <th>表头4</th>
    </tr>
  </thead>
  <tfoot>
    <tr>
      <td>表底1</td>
      <td>表底2</td>
      <td>表底3</td>
      <td>表底4</td>
    </tr>
  </tfoot>
  <tbody>
    <tr>
      <td>行1列1</td>
      <td>行1列2</td>
      <td>行1列3</td>
      <td>行1列4</td>
    </tr>
    <tr>
      <td>行2列1</td>
      <td>行2列2</td>
      <td>行2列3</td>
      <td>行2列4</td>
    </tr>
     <tr>
      <td>行3列1</td>
      <td>行3列2</td>
      <td>行3列3</td>
      <td>行3列4</td>
    </tr>
    <tr>
      <td>行4列1</td>
      <td>行4列2</td>
      <td>行4列3</td>
      <td>行4列4</td>
    </tr>
  </tbody>
</table>

无样式表现:

运行代码框

    [Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]

定义CSS样式:

运行代码框

    [Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]

css部分:

table.tab{
 border :1px black solid;
}

table.tab .g1 .c1
{
 background-color :Yellow;
 width:50px;
}
table.tab .g1 .c2
{
 background-color :  Lime;
 width : 100px;

}
table.tab .g1 .c3{
 background-color :  Green;
 width : 140px;
}
table.tab colgroup.g2{
 background:Teal url("") repeat top center;
 width : 200px;
 /* IE only start */
 /* 非IE的浏览器都不支持非width background以外的定义 */
 color : White;
 text-align : right;
 /* IE only end */
}
table.tab thead th
{
 background-color : Black;/*由于colgroup 定义了背景 th没定义 会因浏览器不同解析不同*/
 /*IE,Opera,Netscape会使用colgroup 定义的背景  MOZ系列的不会 非WIN系统浏览未测试 */
 color : White;
}
table.tab tfoot td
{
 background-color : Gray;

表格的模拟

1、模拟前的建议:

DIV就是DIV 而不是table,极力反对变下面这样的DIV模拟表格,偶尔也考虑考虑一下亲和力

<div>
    <div>
        <div>...</div>
    </div>
</div>
 

2、两列多行的数据显示:

两列多行的数据显示应用得最多的是文章列表之类的,一般来说主要由标题,时间组成的.
我选择ol来做~是下面演示的是有有序列表~可能你会问我~为什么不用ul呢??
在参考中说到ol:绘制文本的编号列表,ul:绘制文本的项目符号列表 简单的说就是ol是有序列表,ul是无序列表
html部分

<ol>
    <li><a href="#" title="晚上我没吃饭">晚上我没吃饭</a>2-13</li>
    <li><a href="#" title="今天是中国的情人节,要一个人过">今天是中国的情人节,要一个人过</a>2-12</li>
    <li><a href="#" title="下午朋友来看我">下午朋友来看我</a>2-11</li>
    <li><a href="#" title="^_^ 发工资拉">^_^ 发工资拉,</a>2-10</li>
    <li><a href="#" title="...">...........</a> ....</li>
</ol>

运行代码框

    [Ctrl+A 全部选择 提示:你可先修改部分代码,再按运行]

CSS部分

ol.news{
    width:400px;/*装饰用的~只限显示的数据总宽度 */
    list-style-type :none;/*去掉列表数据*/
}
ol.news li{
    text-align:right;/* 把文本右对齐,主要的作用是把时间放在右边*/
    clear:both;/*清行*/
}
ol.news li a{
    float:left;
    display : inline;/* 再把主要显示的内容浮动到左边*/
    text-align:left;/* 文本左对齐,可选~保证更多的浏览器是左对齐*/
}

运行代码框