hey,guys.我是poem23.
本篇文章主要介绍了表格和表单标签,给出了几个值得尝试的例子。
注:为方便查看,代码部分仅复制了body中的内容。
目录
1.表格标签
表格是实际开发中非常常用的标签:
1.表格的主要作用
2.表格的基本用法
1.1表格的主要作用
表格主要是用于显示、展示数据,因为它可以让数据显示的非常规整,可读性非常好。特别是后台展示数据的时候,能够熟练运用表格就显得很重要。一个清爽简约的表格能够把复杂的数据表现得很有条理。
1.2表格的基本语法
<table>
<tr>
<td>单元格内的文字</td>
...
</tr>
...
</table>
1.
<table></table>
是用于定义表格的标签。
2.<tr></tr>
标签用于定义表格中的行,必须嵌套在<table></table>
标签中。
3.<td></td>
用于定义标签的单元格,必须嵌套在<tr></tr>
标签中。
4.字母td表示表格数据(table data),即数据单元格的内容。
代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<table>
<tr><td>姓名</td> <td>性别</td> <td>年龄</td></tr>
<tr><td>刘德华</td> <td>男</td> <td>23</td></tr>
<tr><td>张学友</td> <td>男</td> <td>24</td></tr>
<tr><td>郭富城</td> <td>男</td> <td>21</td></tr>
<tr><td>黎明</td> <td>男</td> <td>25</td></tr>
</table>
</body>
</html>
效果:
1.3表头单元格标签
一般表头单元格位于表格的第一行或第一列,表头单元格里面的文本内容加粗居中显示。
<th>
标签表示HTML表格的表头部分(table head的缩写)
<table>
<tr>
<th>姓名</th>
...
</tr>
...
</table>
总结:表头单元格也是单元格,常用于表格第一行,突出重要性,表头单元格里的文字会加粗居中显示。
代码:
<body>
<table>
<tr><th>姓名</th> <th>性别</th> <th>年龄</th></tr>
<tr><td>刘德华</td> <td>男</td> <td>23</td></tr>
<tr><td>张学友</td> <td>男</td> <td>24</td></tr>
<tr><td>郭富城</td> <td>男</td> <td>21</td></tr>
<tr><td>黎明</td> <td>男</td> <td>25</td></tr>
</table>
</body>
效果:
1.4表格属性
表格标签这部分我们其实开发并不常用,后面通过CSS来设置。
目的有两个:
1.记住这些英语单词,后面CSS会使用。
2.直观感受表格的外观形态。
这些标签要写到表格标签table里面去
1.align
代码:
<body>
<!-- 这些属性要写到表格标签table里面去 -->
<table align="center">
<tr><th>姓名</th> <th>性别</th> <th>年龄</th></tr>
<tr><td>刘德华</td> <td>男</td> <td>23</td></tr>
<tr><td>张学友</td> <td>男</td> <td>24</td></tr>
<tr><td>郭富城</td> <td>男</td> <td>21</td></tr>
<tr><td>黎明</td> <td>男</td> <td>25</td></tr>
</table>
</body>
效果:
2. border
代码:
<body>
<!-- 这些属性要写到表格标签table里面去 -->
<table align="center" border="1">
<tr><th>姓名</th> <th>性别</th> <th>年龄</th></tr>
<tr><td>刘德华</td> <td>男</td> <td>23</td></tr>
<tr><td>张学友</td> <td>男</td> <td>24</td></tr>
<tr><td>郭富城</td> <td>男</td> <td>21</td></tr>
<tr><td>黎明</td> <td>男</td> <td>25</td></tr>
</table>
</body>
效果:
3.cellpadding
代码:
<body>
<!-- 这些属性要写到表格标签table里面去 -->
<table align="center" border="1" cellpadding="20">
<tr><th>姓名</th> <th>性别</th> <th>年龄</th></tr>
<tr><td>刘德华</td> <td>男</td> <td>23</td></tr>
<tr><td>张学友</td> <td>男</td> <td>24</td></tr>
<tr><td>郭富城</td> <td>男</td> <td>21</td></tr>
<tr><td>黎明</td> <td>男</td> <td>25</td></tr>
</table>
</body>
效果:(内容和单元格边框之间的距离)
4.cellspacing
代码:
<body>
<!-- 这些属性要写到表格标签table里面去 -->
<table align="center" border="1" cellpadding="20" cellspacing="0">
<tr><th>姓名</th> <th>性别</th> <th>年龄</th></tr>
<tr><td>刘德华</td> <td>男</td> <td>23</td></tr>
<tr><td>张学友</td> <td>男</td> <td>24</td></tr>
<tr><td>郭富城</td> <td>男</td> <td>21</td></tr>
<tr><td>黎明</td> <td>男</td> <td>25</td></tr>
</table>
</body>
效果:(单元格和单元格之间的距离)
5.width
代码:
<body>
<!-- 这些属性要写到表格标签table里面去 -->
<table align="center" border="1" cellspacing="0" width="500" height="249">
<tr><th>姓名</th> <th>性别</th> <th>年龄</th></tr>
<tr><td>刘德华</td> <td>男</td> <td>23</td></tr>
<tr><td>张学友</td> <td>男</td> <td>24</td></tr>
<tr><td>郭富城</td> <td>男</td> <td>21</td></tr>
<tr><td>黎明</td> <td>男</td> <td>25</td></tr>
</table>
</body>
效果:(设置表格的宽度和高度)
小说排行榜案例
代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<!-- 这些属性要写到表格标签table里面去 -->
<table align="center" border="1" cellspacing="0" width="500" height="249">
<tr><th>排名</th> <th>关键词</th> <th>趋势</th> <th>今日搜索</th> <th>最近七日</th> <th>相关链接</th></tr>
<tr><td>1</td> <td>鬼吹灯</td> <td><image src="down.jpg"></image> <td>345</td> <td>123</td> <td><a href="https://tieba.baidu.com/">贴吧</a> <a href="#">图片</a> <a href="https://baike.baidu.com/">百科</a></td></tr>
<tr><td>2</td> <td>盗墓笔记</td> <td><image src="down.jpg"></image> <td>124</td> <td>675432</td> <td><a href="https://tieba.baidu.com/">贴吧</a> <a href="#">图片</a> <a href="https://baike.baidu.com/">百科</a></td></tr>
<tr><td>3</td> <td>西游记</td> <td><image src="up.jpg"></image> <td>212</td> <td>7654</td> <td><a href="https://tieba.baidu.com/">贴吧</a> <a href="#">图片</a> <a href="https://baike.baidu.com/">百科</a></td></tr>
<tr><td>4</td> <td>东游记</td> <td><image src="up.jpg"></image> <td>23</td> <td>75645</td> <td><a href="https://tieba.baidu.com/">贴吧</a> <a href="#">图片</a> <a href="https://baike.baidu.com/">百科</a></td></tr>
<tr><td>5</td> <td>甄嬛传</td> <td><image src="down.jpg"></image> <td>121</td> <td>7676</td> <td><a href="https://tieba.baidu.com/">贴吧</a> <a href="#">图片</a> <a href="https://baike.baidu.com/">百科</a></td></tr>
<tr><td>6</td> <td>水浒传</td> <td><image src="up.jpg"></image> <td>576576</td> <td>1231421</td> <td><a href="https://tieba.baidu.com/">贴吧</a> <a href="#">图片</a> <a href="https://baike.baidu.com/">百科</a></td></tr>
<tr><td>7</td> <td>三国演义</td> <td><image src="up.jpg"></image> <td>234</td> <td>7686</td> <td><a href="https://tieba.baidu.com/">贴吧</a> <a href="#">图片</a> <a href="https://baike.baidu.com/">百科</a></td></tr>
</table>
</body>
</html>
效果:
1.5表格结构标签
使用场景:因为表格可能很长,为了更好的表示表格的语义,可以将表格分割成表格头部和表格主体两大部分。
在表格标签中,分别用:
<thead>
标签表示表格的头部区域,<tbody>
标签,表示表格的主体区域。这样可以更好的分清表格结构。
1.<thead></thead>
:用于定义表格的头部,<thead>
内部必须拥有<tr>
标签。一般是位于第一行。
2.<tbody></tbody>
:用于定义表格的主体,主要用于放数据本体。
1.6合并单元格
特殊情况下,可以把多个单元格合并为一个单元格,这里提供最简单的合并单元格的情况。
合并单元格方式:
- 跨行合并:rowspan=“合并单元格的个数”
- 跨列合并:colspan=“合并单元格的个数”
目标单元格:(写合并代码)
- 跨行:最上侧单元格为目标单元格,写合并代码。
- 跨列:最左侧单元格为目标单元格,写合并代码。
合并单元格三步曲:
1.先确定是跨行还是跨列合并。
2.找到目标单元格。写上合并方式=合并的单元格数量。比如:<td colspan="2"></td>
3.删除多余的单元格。
1.跨行合并
代码:
<body>
<table width="500" height="249" border="1" cellspacing="0">
<tr>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td rowspan="2"></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
</tr>
</table>
</body>
效果:
2.跨列合并
代码:
<body>
<table width="500" height="249" border="1" cellspacing="0">
<tr>
<td></td>
<td colspan="2"></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
<tr>
<td></td>
<td></td>
<td></td>
</tr>
</table>
</body>
效果:
1.7表格总结
2.列表标签
表格是用来显示数据的,那么列表就是用来布局的
。
列表
最大的特点就是整齐、整洁、有序,它作为布局会更加自由和方便。
根据使用场景的不同,列表可以分为三大类:无序列表、有序列表和自定义列表
。
2.1无序列表(重点)
<ul>
标签表示HTML页面中项目的无序列表,一般会以项目符号呈现列表项,而列表项使用<li>
标签定义。
无序列表的基本语法格式如下:
<ul>
<li>列表项1</li>
<li>列表项2</li>
<li>列表项3</li>
...
</ul>
1.无序列表的各个列表项之间没有顺序级别之分,是并列的。
2.<ul></ul>
中只能嵌套<li></li>
,直接在<ul></ul>
标签中输入输入其他标签或者文字的做法是不被允许的。(很不专业哦~)
3.<li>
与</li>
之间相当于一个容器,可以容纳所有元素。
4.无序列表会带有自己的样式属性,但在使用时,我们会使用CSS来设置。
代码:
<body>
<h4>您喜欢的食物?</h4>
<ul>
<li>榴莲</li>
<li>臭豆腐</li>
<li>鲱鱼罐头</li>
</ul>
</body>
效果:
2.2有序列表(理解)
有序列表即为有排列顺序的列表,其各个列表会按照一定的顺序排列定义。
在HTML标签中,
<ol>
标签用于定义有序列表,列表以数字来显示,并且使用<li>
标签来定义列表项。
有序列表的基本语法格式如下:
<ol>
<li>列表项1</li>
<li>列表项2</li>
<li>列表项3</li>
...
</ol>
1.
<ol></ol>
中只能嵌套<li></li>
,直接在<ol></ol>
标签中输入输入其他标签或者文字的做法是不被允许的。
2.<li>
与</li>
之间相当于一个容器,可以容纳所有元素。
3.有序列表会带有自己的样式属性,但在使用时,我们会使用CSS来设置。
代码:
<body>
<h4>粉丝排行榜</h4>
<ol>
<li>刘德华 10000</li>
<li>刘若英 1000</li>
<li>张三 1</li>
</ol>
</body>
效果:
2.3自定义列表
自定义列表的使用场景:
自定义列表常用于对术语或名词进行解释和描述,定义列表的列表项前没有任何项目符号。
在HTML标签中,
<dl>
标签用于定义描述列表(或定义列表),该标签会与<dt>
(定义项目/名字)和<dd>
(描述每一个项目/名字)一起使用。
其基本语法如下:
<dl>
<dt>名词1</dt>
<dd>名词1解释1</dd>
<dd>名词2解释2</dd>
</dl>
1.
<dl>
和</dl>
里面只能包含<dt>
和<dd>
2.<dt>
和<dd>
的个数没有限制,经常是一个<dt>
对应多个<dd>
。
3.<dt>
和<dd>
是并列的兄弟关系,<dd>
围绕<dt>
展开,并不可以理解为包含关系。
代码:
<body>
<dl>
<dt>关注我们</dt>
<dd>新浪微博</dd>
<dd>官方微信</dd>
<dd>联系我们</dd>
</dl>
</body>
效果:(dd前的空格在学习了CSS后可以修饰)
2.4列表总结
3.表单标签
现实中的表单,我们去银行办理信用卡填写的单子。
网页中的表单展示
3.1为什么需要表单
使用表单的目的是为了收集用户信息。
在我们的网页中,我们也需要跟用户进行交互,收集用户资料,此时就需要表单。
3.2表单的组成
在HTML中,一个完整的的表单通常由表单域
、表单控件(也称为表单元素)
和提示信息
3个部分构成。
3.3表单的组成
表单域
是一个包含表单元素的区域
。
在HTML文件中,
<form>
标签用于定义表单,以实现用户信息的收集和传递。
<form>会把它范围内的表单元数信息提交给服务器。
<form action="url地址" method="提交方式" name="表单域名称">
各种表单元素控件
</form>
基础班暂时不用表单域提交数据,只需要写上form标签即可。
这里只需要记住两点:
1.在我们写表单元素之前,应该有个表单域把他们进行包含。
2.表单域是form标签。
代码:
<body>
<form action="demo.php" method="POST" name="name1">
</form>
</body>
3.4表单控件(表单元素)
在表单域中可以定义各种表单元素,这些表单元素就是允许客户在表单中输入或者选择的内容控件。
3.4.1<input>表单元素
input是输入的意思,而在表单元素中<input>标签用于收集用户信息
。
在标签中,包含一个type属性,根据不同的type属性,输入字段拥有很多种形式(可以是文本字段、复制框、掩码后的文本控件、单选按钮、按钮等)。
<input type="属性值" />
1.
<input />
标签为单标签
2. type属性设置不同的属性是用来指定不同的控件类型。
代码:
<body>
<form>
<!-- text 文本框 用户可以向里面输入任何文字 -->
用户名:<input type="text"> <br>
<!-- password 密码框 用户看不见输入的密码 -->
密码:<input type="password"> <br>
<!-- radio 单选按钮 可以实现多选一 -->
性别:<input type="radio">男<input type="radio">女<input type="radio">人妖<br>
<!-- checkbox 复选框 可以是实现多选 -->
爱好:<input type="checkbox">吃饭<input type="checkbox">睡觉<input type="checkbox">打豆豆
</form>
</body>
效果:
除type属性外,标签还有很多其他属性,其常用属性如下:
1.name和value是每个表单元素都有的独特属性值,主要给后台人员使用。
2.name表单元素的名字,要求单选按钮和复选框要有相同的name值
。
3.checked属性主要是针对对于单元按钮和复选框。
主要作用一打开页面,就要可以默认选中某个表单元素。
4.maxlength是用户可以在表单元素输入最大字符数,一般较少使用。
代码:
<body>
<form>
<!-- text 文本框 用户可以向里面输入任何文字 -->
用户名:<input type="text" name="username" value="请输入用户名" maxlength="6"> <br>
<!-- password 密码框 用户看不见输入的密码 -->
密码:<input type="password" name="pwd"> <br>
<!-- radio 单选按钮 可以实现多选一 -->
<!-- name 是表单元素名字 这里性别单选按钮必须有相同的名字name 才可以实现多选一 -->
<!-- 单选按钮和复选框可以设置checked属性,当页面打开的时候就可以默认选中这个按钮 -->
性别:<input type="radio" name="sex" value="男">男<input type="radio" name="sex" value="女" checked="checked">女<input type="radio" name="sex" value="人妖">人妖<br>
<!-- checkbox 复选框 可以是实现多选 -->
爱好:<input type="checkbox" name="hobby" value="吃饭" checked="checked">吃饭<input type="checkbox" name="hobby" value="睡觉">睡觉<input type="checkbox" name="hobby" value="打豆豆">打豆豆<br>
<!-- 点击了提交按钮,可以把表单域form里面的表单元素 里面的值 提交给后台服务器 -->
<input type="submit" value="免费注册">
<!-- 重置按钮可以还原表单元素初始的默认状态 -->
<input type="reset" value="重新填写">
<!-- 普通按钮button 后期结合js搭配使用 -->
<input type="button"value="获取短信验证码"><br>
<!-- 文件域 使用场景 上传文件使用的 -->
上传头像:<input type="file">
</form>
</body>
效果:
3.4.2<label>标签
<label>
标签为input元素定义标注(标签)。
<label>
标签用于绑定一个表单元素,当点击
语法:
<label for="sex">男</label>
<input type="radio" name="sex" id="sex" />
代码:
<body>
<label for="text">用户名:</label><input type="text" id="text">
<input type="radio" id="nan" name="sex"><label for="nan">男</label>
<input type="radio" id="nv" name="sex"><label for="nv">女</label>
</body>
效果:
核心:
3.4.3<select>表单元素
使用场景:在页面中,如果有多个选项让用户选择,并且想要节约页面空间时,我们可以使用<select>
标签控件定义下拉列表
。
语法:
<select>
<option>选项1</option>
<option>选项2</option>
<option>选项3</option>
...
</select>
1.
<select>
中至少包含一对<option>
。
2.在<option>
中定义selected= "selected"时,当前项即为默认选中项。
代码:
<body>
<form>
籍贯:
<select>
<option>山东</option>
<option>山西</option>
<option selected="selected">陕西</option>
<option>北京</option>
<option>上海</option>
<option>四川</option>
</select>
</form>
</body>
效果:
3.4.4<textarea>表单元素
使用场景:当用户输入内容较多时,我们就不能使用文本框表单了,此时我们可以使用<textarea>
标签。
在表单元素中,<textarea>
标签是用于定义多行文本输入的控件。
使用多行文本输入,可以输入更多的文字,该控件常见于留言板、评论。
语法:
<textarea rows="3" cols="20">
文本内容
</textarea>
1.通过标签可以轻松地创建多行文本输入框。
2.cols=“每行中的字符数”,rows=“显示的行数”(我们在实际开发中不会使用,都是用CSS来改变大小
)。
代码:
<body>
<form>
今日反馈:
<textarea cols="50" rows="5">这个反馈留言是textarea来做的</textarea>
</form>
</body>
效果:
综合案例
题目:
代码:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>世纪佳缘-你在我也在</title>
</head>
<body>
<h4>青春不常在,抓紧谈恋爱</h4>
<table width="600">
<!-- 第一行 -->
<tr>
<td>性别</td>
<td>
<form>
<input type="radio" name="sex" value="man" id="man" checked="checked"><label for="man"><image src="man.jpg"></image>男</label>
<input type="radio" name="sex" value="women" id="women"><label for="women"><image src="women.jpg"></image>女</label>
</form>
</td>
</tr>
<!-- 第二行 -->
<tr>
<td>生日</td>
<td>
<form>
<select>
<option selected="selected">--请选择年--</option><option>1998</option><option>1999</option><option>2000</option>
</select>
<select>
<option selected="selected">--请选择月--</option><option>1</option><option>2</option><option>3</option>
</select>
<select>
<option selected="selected">--请选择日--</option><option>1</option><option>2</option><option>3</option>
</select>
</form>
</td>
</tr>
<!-- 第三行 -->
<tr>
<td>所在地区</td>
<td>
<form>
<input type="text" name="area" value="北京思密达">
</form>
</td>
</tr>
<!-- 第四行 -->
<tr>
<td>婚姻状况</td>
<td>
<form>
<input type="radio" name="hunyin" value="weihun" id="weihun" checked="checked"><label for="weihun">未婚</label>
<input type="radio" name="hunyin" value="yihun" id="yihun"><label for="yihun">已婚</label>
<input type="radio" name="hunyin" value="lihun" id="lihun"><label for="lihun">离婚</label>
</form>
</td>
</tr>
<!-- 第五行 -->
<tr>
<td>学历</td>
<td>
<input type="text" name="area" value="幼儿园">
</td>
</tr>
<!-- 第六行 -->
<tr>
<td>喜欢的类型</td>
<td>
<form>
<input type="checkbox" name="type" value="妩媚的" id="wumei"><label for="wumei">妩媚的</label>
<input type="checkbox" name="type" value="可爱的" id="keai"><label for="keai">可爱的</label>
<input type="checkbox" name="type" value="小鲜肉" id="xianrou"><label for="xianrou">小鲜肉</label>
<input type="checkbox" name="type" value="老腊肉" id="larou"><label for="larou">老腊肉</label>
<input type="checkbox" name="type" value="都喜欢" id="all"><label for="all">都喜欢</label>
</form>
</td>
</tr>
<!-- 第七行 -->
<tr>
<td>自我介绍</td>
<td>
<form>
<textarea cols="20" rows="2">自我介绍</textarea>
</form>
</td>
</tr>
<!-- 第八行及以后 -->
<tr>
<td></td>
<td>
<input type="submit" value="免费注册">
</td>
</tr>
<tr>
<td></td>
<td>
<form>
<input type="checkbox" value="我同意注册条款并加入会员" id="agree" checked="checked"><label for="agree">我同意注册条款并加入会员</label>
</form>
</td>
</tr>
<tr>
<td></td>
<td>
<a href="#">我是会员,立即登录</a>
</td>
</tr>
<tr>
<td></td>
<td>
<h5>我承诺</h5>
<ul>
<li>年满18岁、单身</li>
<li>抱着严肃的态度</li>
<li>真诚寻找另一半</li>
</ul>
</td>
</tr>
</table>
</body>
</html>
效果:
5.查阅文档
推荐的网址:
百度:https://www.baidu.com/
W3C:https://www.w3school.com.cn/
MDN:https://developer.mozilla.org/zh-CN/
这就是本篇文章的全部内容了,对应视频p32-p60的内容。
下一篇文章会开始介绍CSS相关内容,感谢浏览。
