每次做表格都是现查的,今天就做个了断吧!(以后查自己写的)
生成基本的表格
生成表格的基本三个元素就是table,tr,td。table就是HTML文档中用来表示表格,tr表示表格中的行,td表示行中的单元格。用这三个元素就可以做出一个简单的表格。
<table>
<tr>
<td>Rank</td>
<td>Name</td>
<td>Color</td>
<td>Size</td>
</tr>
<tr>
<td>Favorite</td>
<td>Apples</td>
<td>Green</td>
<td>Medium</td>
</tr>
<tr>
<td>2nd Favorite</td>
<td>Oranges</td>
<td>Orange</td>
<td>Large</td>
</tr>
<tr>
<td>3nd Favorite</td>
<td>Bananas</td>
<td>Yellow</td>
<td>Large</td>
</tr>
</table>
添加表头单元格
th用来添加表头单元格,区分数据和对数据的说明。
<table>
<tr>
<th>Rank</th>
<th>Name</th>
<th>Color</th>
<th>Size</th>
</tr>
<tr>
<th>Favorite</th>
<td>Apples</td>
<td>Green</td>
<td>Medium</td>
</tr>
<tr>
<th>2nd Favorite</th>
<td>Oranges</td>
<td>Orange</td>
<td>Large</td>
</tr>
<tr>
<th>3nd Favorite</th>
<td>Bananas</td>
<td>Yellow</td>
<td>Large</td>
</tr>
</table>
为表格添加结构
在上面的两种表格中没有表格线,一点都不像正规的表格。可以用CSS添加样式,也可以用thead,tbody,tfoot来为表格添加结构。
1.用CSS来给表格做个修饰
tr>th{
text-align: center;
background: grey;
color: white;
}
2.表示表头和表格主题
tbody元素包含表格的主题部分,但不包含tfoot和thead表示的表脚行和表头行,注意的是即使没有tbody元素,在浏览器处理table元素的时候会自动插入tbody元素,因此有些时候如table>tr这样的选择器会失效,这时候就应该写成table>tbody>tr或者直接写成tbody>tr。
thead用来标记表格的标题行。
下面是给表格添加thead和tbody,样式上并没有什么改变,但使表格的结构更加清晰了。
<table>
<thead>
<tr>
<th>Rank</th>
<th>Name</th>
<th>Color</th>
<th>Size</th>
</tr>
</thead>
<tbody>
<tr>
<th>Favorite</th>
<td>Apples</td>
<td>Green</td>
<td>Medium</td>
</tr>
<tr>
<th>2nd Favorite</th>
<td>Oranges</td>
<td>Orange</td>
<td>Large</td>
</tr>
<tr>
<th>3rd Favorite</th>
<td>Bananas</td>
<td>Yellow</td>
<td>Large</td>
</tr>
</tbody>
</table>
3.添加表脚
tfoot元素HTML5之前只能出现在tbody元素之前,HTML5之后可以放在tbody元素之后,或者是最后一个tr元素。(把thead中的内容放到tfoot中啦。)
制作不规则表格
对于跨越几行或者几列的表格可以用td,th元素的colspan和rowspan属性。
<table>
<thead>
<tr>
<th>Rank</th>
<th>Name</th>
<th>Color</th>
<th colspan="2">Size & Votes</th>
</tr>
</thead>
<tbody>
<tr>
<th>Favorite</th>
<td>Apples</td>
<td>Green</td>
<td>Medium</td>
<td>500</td>
</tr>
<tr>
<th>2nd Favorite</th>
<td>Oranges</td>
<td>Orange</td>
<td>Large</td>
<td>450</td>
</tr>
<tr>
<th>3rd Favorite</th>
<td>Pomegranate</td>
<td colspan="2" rowspan="2">Pomegranates and cherries can both come in a range of colors sizes</td>
<td>203</td>
</tr>
<tr>
<th rowspan="2">Joint 4th</th>
<td>Cherries</td>
<td rowspan="2">75</td>
</tr>
<tr>
<td>Pineapple</td>
<td>Brown</td>
<td>Very Large</td>
</tr>
</tbody>
<tfoot>
<tr>
<th colspan="5">Hongyu-html5</th>
</tr>
</tfoot>
</table>
将表头与单元格关联起来
td和th元素都定义了headers他用于对屏幕阅读器和其他残障辅助技术来简化对表格的处理,headers属性的值可以被设置成一个或者多个单元个的id属性值。
就是下面的这个样子。
<table>
<thead>
<tr>
<th id="rank">Rank</th>
<th id="name">Name</th>
<th id="color">Color</th>
<th colspan="2" id="sizeAndVotes">Size & Votes</th>
</tr>
</thead>
<tbody>
<tr>
<th id="first" headers="rank">Favorite</th>
<td headers="name first">Apples</td>
<td headers="color first">Green</td>
<td headers="sizeAndVotes first">Medium</td>
<td headers="sizeAndVotes first">500</td>
</tr>
<tr>
<th id="second">2nd Favorite</th>
<td headers="name second">Oranges</td>
<td headers="color sceond">Orange</td>
<td headers="sizeAndVotes second">Large</td>
<td headers="sizeAndVotes second">450</td>
</tr>
</tbody>
</table>
为表格添加标题
caption 元素可以为表格定义一个标题,并将其与表格关联起来。
<table>
<caption>Results of the 2011 Fruit Survey </caption>
<thead>
<tr>
<th id="rank">Rank</th>
<th id="name">Name</th>
<th id="color">Color</th>
<th colspan="2" id="sizeAndVotes">Size & Votes</th>
</tr>
</thead>
<tbody>
<tr>
<th id="first" headers="rank">Favorite</th>
<td headers="name first">Apples</td>
<td headers="color first">Green</td>
<td headers="sizeAndVotes first">Medium</td>
<td headers="sizeAndVotes first">500</td>
</tr>
<tr>
<th id="second">2nd Favorite</th>
<td headers="name second">Oranges</td>
<td headers="color sceond">Orange</td>
<td headers="sizeAndVotes second">Large</td>
<td headers="sizeAndVotes second">450</td>
</tr>
<tr>
<th >3rd Favorite</th>
<td>Pomegranate</td>
<td colspan="2" rowspan="2">Pomegranates and cherries can both come in a range of colors sizes</td>
<td>203</td>
</tr>
<tr>
<th rowspan="2">Joint 4th</th>
<td>Cherries</td>
<td rowspan="2">75</td>
</tr>
<tr>
<td>Pineapple</td>
<td>Brown</td>
<td>Very Large</td>
</tr>
</tbody>
<tfoot>
<tr>
<th colspan="5">Hongyu-html5</th>
</tr>
</tfoot>
</table>
处理列
HTML中的表格是基于行的,就是需要一行一行的组件表格。若想创建基于列的可以使用colgroup和col元素。
colgroup元素的影响范围覆盖了列中所有的单元格,也包含了thead和tfoot,即使这些单元格不包含在其内部。
<table>
<caption>Results of the 2011 Fruit Survey </caption>
<colgroup id="colgroup1" span="3"/>
<colgroup id="colgroup2" span="2"/>
<thead>
<tr>
<th id="rank">Rank</th>
<th id="name">Name</th>
<th id="color">Color</th>
<th colspan="2" id="sizeAndVotes">Size & Votes</th>
</tr>
</thead>
<tbody>
<tr>
<th id="first" headers="rank">Favorite</th>
<td headers="name first">Apples</td>
<td headers="color first">Green</td>
<td headers="sizeAndVotes first">Medium</td>
<td headers="sizeAndVotes first">500</td>
</tr>
<tr>
<th id="second">2nd Favorite</th>
<td headers="name second">Oranges</td>
<td headers="color sceond">Orange</td>
<td headers="sizeAndVotes second">Large</td>
<td headers="sizeAndVotes second">450</td>
</tr>
<tr>
<th >3rd Favorite</th>
<td>Pomegranate</td>
<td colspan="2" rowspan="2">Pomegranates and cherries can both come in a range of colors sizes</td>
<td>203</td>
</tr>
<tr>
<th rowspan="2">Joint 4th</th>
<td>Cherries</td>
<td rowspan="2">75</td>
</tr>
<tr>
<td>Pineapple</td>
<td>Brown</td>
<td>Very Large</td>
</tr>
</tbody>
<tfoot>
<tr>
<th colspan="5">Hongyu-html5</th>
</tr>
</tfoot>
</table>
也可以不使用colgroup元素的span属性,改用col元素指定组中的各列。注意col元素的父元素只能是colgroup,使用col能更好的控制表格的表现。在未设置span的情况下每个col元素 表示列组中的一列。
<colgroup id="colgroup1">
<col id="col1And2" span="2"/>
<col id="col3"/>
</colgroup>
<colgroup id="colgroup2" span="2"/>
设置表格边框
table元素设置了border属性,浏览器遇到border属性就会在表格的每一个单元格上绘制边框线。table也可用作布局,使用border属性就是在告诉浏览器将这个table当作表格对待。
<table border="1"></table>