HTML5表格_动力节点Java学院整理


Posted in HTML / CSS onJuly 11, 2017

表格的作用是显示二维数据,在HTML5中不再允许用表格控制页面内容的布局,而是采用新增的CSS表格特性(这里不涉及CSS,将在后面介绍)。下面主要介绍用于制作表格的HTML元素。

构建表格

表格的基本元素包括:table、tr和td。
table表示HTML文档中的表格,支持border属性,用于定义表格边框的宽度;
tr表示表格中的行;
td表示表格中的单元格,包括如下属性:
  1)colspan:规定单元格可横跨的列数;
  2)rowspan:规定单元格可横跨的行数;
  3)headers:规定与单元格相关的标头,该属性不会在普通浏览器中产生任何视觉变化,但可以被屏幕阅读器使用。

<table>
 <tr>
  <td>Apples</td>
  <td>Green</td>
  <td>Medium</td>
 </tr>
 <tr>
  <td>Oranges</td>
  <td>Orange</td>
  <td>Large</td>
 </tr>
</table>

上面定义了一个两行、三列的表格,使用表格的好处是:浏览器会保证列的宽度满足最宽的内容,让行的高度满足最高的单元格。

表格边框

使用table元素的border属性,可以为表格添加边框。

<table border="1">
 <tr>
  <td>Apples</td>
  <td>Green</td>
  <td>Medium</td>
 </tr>
 <tr>
  <td>Oranges</td>
  <td>Orange</td>
  <td>Large</td>
 </tr>
</table>

浏览器的默认边框不太美观,通常还需要用CSS来为为各种元素重设边框样式。

不规则表格

使用单元格的colspan和rowspan属性可以构建不规则表格,使表格的某些行或者列跨越多个单元格,下面是一个单元格跨多列的一个例子:

<table border="1">
  <tr>
    <th>Month</th>
    <th>Savings</th>
  </tr>
  <tr>
    <td colspan="2">January</td>
  </tr>
  <tr>
    <td colspan="2">February</td>
  </tr>
</table>

下面是一个单元格跨多行的一个例子:

<table border="1">
  <tr>
    <th>Month</th>
    <th>Savings</th>
  </tr>
  <tr>
    <td>January</td>
    <td>$100.00</td>
    <td rowspan="2">$50</td>
  </tr>
  <tr>
    <td>February</td>
    <td>$10.00</td>
  </tr>
</table>

表头

th元素用于为表格添加表头,可以用来区分数据和对数据的说明。th元素支持如下属性:
  1)colspan:规定单元格可横跨的列数;
  2)rowspan:规定单元格可横跨的行数;
  3)scope:定义将表头数据与单元数据相关联的方法;
  3)headers:由空格分隔的表头单元格ID列表,为数据单元格提供表头信息,该属性不会在普通浏览器中产生任何视觉变化,但可以被屏幕阅读器使用。

<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>3rd Favorite:</th>
  <td>Pomegranate</td><td>A kind of greeny-red</td>
  <td>Varies from medium to large</td>
 </tr>
</table>

可以在一行中混合使用th和td。

让单元格关联表头

使用td的headers属性可以将单元格和表头关联,关联的目的主要是供屏幕阅读器和其他残障辅助技术用来简化对表格的处理。headers属性可以为一个或多个th单元格的id属性值:

<table border="1" width="100%">
  <tr>
 <th id="name">Name</th>
 <th id="Email">Email</th>
 <th id="Phone">Phone</th>
 <th id="Address">Address</th>
  </tr>
  <tr>
 <td headers="name">George Bush</td>
 <td headers="Email">someone@example.com</td>
 <td headers="Phone">+789451236</td>
 <td headers="Address">Fifth Avenue New York,USA</td>
  </tr>
</table>

构造复杂表头

使用th的colspan和rowspan属性可以构造复杂表头。

<table border="1">
  <tr>
    <th colspan="2">Company in USA</th>
  </tr>
  <tr>
    <th>Name</th><th>Addr</th>
  </tr>
  <tr>
    <td>Apple, Inc.</td>
    <td>1 Infinite Loop Cupertino, CA 95014</td>
  </tr>
  <tr>
    <td>Google, Inc.</td>
    <td>1600 Amphitheatre Parkway Mountain View, CA 94043</td>
  </tr>
</table>

为表格添加结构

可以使用thead、tbody和tfoot元素来为表格添加结构,这样可以让为表格各个部分添加CSS样式变得更加容易。
1)表格主题
tbody元素表示构成表格主题的全体行,不包括表头行(thead元素表示)和表脚行(tfoot元素表示)。
注意大多数浏览器在处理table元素时都会自动插入tbody元素。
2)表格表头
thead元素用来标记表格的标题行。如果没有thead元素的话,所有tr元素都会被视为表格主体的一部分。
3)添加脚注
tfoot元素用来标记组成表脚的行。在HTML5之前tfoot元素只能出现在tbody元素之前,而在HTML5中则允许将tfoot元素放在tbody之后。
下面是一个综合的例子,里面使用了tbody、thead和tfoot元素。

<table>
 <thead>
  <tr>
   <th>Rank</th><th>Name</th><th>Color</th><th>Size</th>
  </tr>
 </thead>
 <tfoot>
  <tr>
   <th>Rank</th><th>Name</th><th>Color</th><th>Size</th>
  </tr>
 </tfoot>
 <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>Pomegranate</td><td>A kind of greeny-red</td>
   <td>Varies from medium to large</td>
  </tr>
 </tbody>
</table>

为表格添加标题

使用caption元素可以为表格定义一个标题,并将其与表格关联起来。

<table>
 <caption>Results of the 2011 Fruit Survey</caption>
 <thead>
  <tr>
   <th>Rank</th><th>Name</th><th>Color</th><th>Size</th>
  </tr>
 </thead>
 <tfoot>
  <tr>
   <th>Rank</th><th>Name</th><th>Color</th><th>Size</th>
  </tr>
 </tfoot>
 <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>Pomegranate</td><td>A kind of greeny-red</td>
   <td>Varies from medium to large</td>
  </tr>
 </tbody>
</table>

一个表格只能包含一个caption元素,无需是表格的第一个元素,但始终显示在表格上方。

列分组

在表格中,由于表格都是按行组建的,导致对列的操作不太方便,例如为表格的某列定义样式。可以使用colgroup元素来指定列的分组。

<html>
<head>
    <style>
        #colgroup1{background-color: red}
        #colgroup2{background-color: green; font-size=small}
    </style>
</head>
<body>
<table width="100%" border="1">
  <colgroup id="colgroup1" span="2" ></colgroup>
  <colgroup id="colgroup2"></colgroup>
  <tr>
    <th>ISBN</th>
    <th>Title</th>
    <th>Price</th>
  </tr>
  <tr>
    <td>3476896</td>
    <td>My first HTML</td>
    <td>$53</td>
  </tr>
  <tr>
    <td>2489604</td>
    <td>My first CSS</td>
    <td>$47</td>
  </tr>
</table>
</body>
</html>

上面的例子中指定了两个列的组,第一个包含前2列,第二个包含剩下的1列,并为不同的分组指定了不同的样式。colgroup的span属性指定扩展几列,如果不指定span属性,也可以指定一个或多个col元素,下面的例子达到了和上面例子一样的效果。

<html>
<head>
    <style>
        #colgroup1{background-color: red}
        #col3{background-color: green; font-size=small}
    </style>
</head>
<body>
<table width="100%" border="1">
  <colgroup id="colgroup1">
 <col id="col1And2" span="2"/>
 <col id="col3"/>
  </colgroup>
  <tr>
    <th>ISBN</th>
    <th>Title</th>
    <th>Price</th>
  </tr>
  <tr>
    <td>3476896</td>
    <td>My first HTML</td>
    <td>$53</td>
  </tr>
  <tr>
    <td>2489604</td>
    <td>My first CSS</td>
    <td>$47</td>
  </tr>
</table>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3使用多列制作瀑布流
May 10 HTML / CSS
CSS实现限制字数功能当对象内文本溢出时显示省略标记
Aug 20 HTML / CSS
CSS3制作Dropdown下拉菜单的方法
Jul 18 HTML / CSS
CSS3制作缩略图的详细过程
Jul 08 HTML / CSS
CSS3 transforms应用于背景图像的解决方法
Apr 16 HTML / CSS
只要五步 就可以用HTML5/CSS3快速制作便签贴特效(图)
Jun 04 HTML / CSS
html5基础标签(html5视频标签 html5新标签用法)
Dec 30 HTML / CSS
实例讲解使用SVG制作loading加载动画的方法
Apr 05 HTML / CSS
HTML5页面直接调用百度地图API获取当前位置直接导航目的地的实现代码
Mar 02 HTML / CSS
Html5之webcoekt播放JPEG图片流
Sep 22 HTML / CSS
Html5页面播放M4a音频文件
Mar 30 HTML / CSS
使用HTML+Css+transform实现3D导航栏的示例代码
Mar 31 HTML / CSS
html5嵌入内容_动力节点Java学院整理
Jul 07 #HTML / CSS
html5定制表单_动力节点Java学院整理
Jul 11 #HTML / CSS
html5文本内容_动力节点Java学院整理
Jul 11 #HTML / CSS
HTML5中视频音频的使用详解
Jul 07 #HTML / CSS
html5组织文档结构_动力节点Java学院整理
Jul 11 #HTML / CSS
html5本地存储_动力节点Java学院整理
Jul 12 #HTML / CSS
html5服务器推送_动力节点Java学院整理
Jul 12 #HTML / CSS
You might like
PHP实现UTF-8文件BOM自动检测与移除实例
2014/11/05 PHP
php脚本守护进程原理与实现方法详解
2017/07/20 PHP
php文件操作之文件写入字符串、数组的方法分析
2019/04/15 PHP
jQuery UI Autocomplete 体验分享
2012/02/14 Javascript
javascript学习(二)javascript常见问题总结
2013/01/02 Javascript
你必须知道的JavaScript 变量命名规则详解
2013/05/07 Javascript
javascript中select下拉框的用法总结
2016/01/07 Javascript
Webpack 实现 AngularJS 的延迟加载
2016/03/02 Javascript
JavaScript实现提交模式窗口后刷新父窗口数据的方法
2017/06/16 Javascript
Easyui在treegrid添加控件的实现方法
2017/06/23 Javascript
基于AngularJs select绑定数字类型的问题
2018/10/08 Javascript
Vue.js的模板语法详解
2020/02/16 Javascript
[45:46]2014 DOTA2国际邀请赛中国区预选赛5.21 HGT VS DT
2014/05/23 DOTA
python求pi的方法
2014/10/08 Python
Python计算回文数的方法
2015/03/11 Python
python2.7实现FTP文件下载功能
2018/04/15 Python
Pandas GroupBy对象 索引与迭代方法
2018/11/16 Python
简单了解python关系(比较)运算符
2019/07/08 Python
基于python实现FTP文件上传与下载操作(ftp&amp;sftp协议)
2020/04/01 Python
Python创建临时文件和文件夹
2020/08/05 Python
Python三维绘图之Matplotlib库的使用方法
2020/09/20 Python
Python中qutip用法示例详解
2020/10/02 Python
python时间time模块处理大全
2020/10/25 Python
COSETTE官网:奢华,每天
2020/03/22 全球购物
.NET程序员的数据库面试题
2012/10/10 面试题
Servlet的实例是在生命周期什么时候创建的?配置servlet最重要的是什么?
2012/05/30 面试题
管理学院毕业生自荐信范文
2014/03/10 职场文书
公务员保密承诺书
2014/03/27 职场文书
2014年惩防体系建设工作总结
2014/12/01 职场文书
电气工程师岗位职责
2015/02/12 职场文书
会议通知
2015/04/15 职场文书
物资采购管理制度
2015/08/06 职场文书
2016年教代会开幕词
2016/03/04 职场文书
雄兵连:第三季先行图公开,天使恶魔联合,银河之力的新力量
2021/06/11 国漫
关于React Native 无法链接模拟器的问题
2021/06/21 Javascript
vue-cli3.0修改打包后的文件名和文件地址,打包后本地运行报错解决
2022/04/06 Vue.js