HTML5权威指南——表格元素

每次做表格都是现查的,今天就做个了断吧!(以后查自己写的)

生成基本的表格

生成表格的基本三个元素就是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>

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值