☀️列表标签
💡目标:
能够使用 无序列表、有序列表、自定义列表 标签,实现网页中列表结构的搭建
⚡️1. 列表的应用场景
♗场景:
在网页中按照行展示关联性的内容,如:新闻列表、排行榜、账单等
♗ 特点:
按照行的方式,整齐显示内容
♗种类:
无序列表、有序列表、自定义列表
⚡️2. 无序列表
♗ 场景:
在网页中表示一组无顺序之分的列表,如:新闻列表。
♗标签组成:
♗ 显示特点:
- 列表的每一项前默认显示圆点标识
♗注意点:
- ul标签中只允许包含li标签
- li标签可以包含任意内容
💻代码演示:
<!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>
<ul>
<li>榴莲</li>
<li>香蕉</li>
<li>苹果</li>
</ul>
</body>
</html>
⚡️3. 有序列表
♗ 场景:
在网页中表示一组有顺序之分的列表,如:排行榜。
♗ 标签组成:
♗ 显示特点:
- 列表的每一项前默认显示序号标识
♗注意点:
- ol标签中只允许包含li标签
- li标签可以包含任意内容
💻代码演示:
<!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>
<ol>
<li>张三:100</li>
<li>李四: 80</li>
</ol>
</body>
</html>
⚡️4. 自定义列表
♗ 场景:
在网页的底部导航中通常会使用自定义列表实现。
♗ 标签组成:
♗显示特点:
- dd前会默认显示缩进效果
♗ 注意点:
- dl标签中只允许包含dt/dd标签
- dt/dd标签可以包含任意内容
💻代码演示:
<!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>
<dl>
<dt>帮助中心</dt>
<dd>账户管理</dd>
<dd>购物指南</dd>
</dl>
</body>
</html>
💻运行效果:
⚡️5. 列表标签-总结
无序列表最常用,有序列表偶尔用,自定义列表底部导航用。
♗ 无序列表
♗ 有序列表
♗ 自定义列
☀️表格标签
⚡️1. 表格的基本标签
♗ 场景:
在网页中以行+列的单元格的方式整齐展示和数据,如:学生成绩表
♗ 基本标签:
♗ 注意点:
- 标签的嵌套关系:table > tr > td
⚡️2. 表格相关属性
♗ 场景:
设置表格基本展示效果
♗ 常见相关属性:
♗ 注意点:
- 实际开发时针对于样式效果推荐用CSS设置
💻代码演示:
<!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, tr包含td -->
<table border="1" width=600 height=400>
<tr>
<td>姓名</td>
<td>成绩</td>
<td>评语</td>
</tr>
<tr>
<td>小哥哥</td>
<td>100分</td>
<td>孩砸, 真棒啊</td>
</tr>
<tr>
<td>郭德纲</td>
<td>150分</td>
<td>没有郭德纲相声早黄了, 有了郭德纲, 相声更黄了</td>
</tr>
</table>
</body>
</html>
💻运行效果:
⚡️3. 表格标题和表头单元格标签
♗ 场景:
在表格中表示整体大标题和一列小标题
♗ 其他标签:
♗ 注意点:
- caption标签书写在table标签内部
- th标签书写在tr标签内部(用于替换td标签)
💻代码演示:
<!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 border="1">
<caption><strong>学生成绩单</strong></caption>
<tr>
<!-- <td></td> -->
<th>姓名</th>
<th>成绩</th>
<th>评语</th>
</tr>
<tr>
<td>张三</td>
<td>100分</td>
<td>真棒, 第一名</td>
</tr>
<tr>
<td>李四</td>
<td>99分</td>
<td>真棒, 第二名</td>
</tr>
<tr>
<td>总结</td>
<td>郎才女貌</td>
<td>真棒, 相亲成功</td>
</tr>
</table>
</body>
</html>
💻运行效果:
⚡️4. 表格的结构标签(了解)
♗ 场景:
让表格的内容结构分组,突出表格的不同部分(头部、主体、底部),使语义更加清晰
♗ 结构标签:
♗ 注意点:
- 表格结构标签内部用于包裹tr标签
- 表格的结构标签可以省略
<!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 border="1">
<caption><strong>学生成绩单</strong></caption>
<thead>
<tr>
<!-- <td></td> -->
<th>姓名</th>
<th>成绩</th>
<th>评语</th>
</tr>
</thead>
<tbody>
<tr>
<td>张三</td>
<td>100分</td>
<td>真棒, 第一名</td>
</tr>
<tr>
<td>李四</td>
<td>99分</td>
<td>真棒, 第二名</td>
</tr>
</tbody>
<tfoot>
<tr>
<td>总结</td>
<td>郎才女貌</td>
<td>真棒, 相亲成功</td>
</tr>
</tfoot>
</table>
</body>
</html>
⚡️5. 合并单元格
🚀5.1 合并单元格-思路
♗ 场景:
将水平或垂直多个单元格合并成一个单元格
♗ 合并单元格步骤:
- 明确合并哪几个单元格
- 通过左上原则,确定保留谁删除谁
• 上下合并→只保留最上的,删除其他
• 左右合并→只保留最左的,删除其他- 给保留的单元格设置:跨行合并(rowspan)或者跨列合并(colspan)
♗注意点:
- 只有同一个结构标签中的单元格才能合并,不能跨结构标签合并(不能跨:thead、tbody、tfoot)
💻代码演示:
<!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 border="1">
<caption><strong>学生成绩单</strong></caption>
<thead>
<tr>
<!-- <td></td> -->
<th>姓名</th>
<th>成绩</th>
<th>评语</th>
</tr>
</thead>
<tbody>
<tr>
<td>张三</td>
<td rowspan="2">100分</td>
<td>真棒, 第一名</td>
</tr>
<tr>
<td>李四</td>
<td>真棒, 第二名</td>
</tr>
</tbody>
<tfoot>
<tr>
<td>总结</td>
<td colspan="2">郎才女貌</td>
</tr>
</tfoot>
</table>
</body>
</html>
☀️表单标签
⚡️1. input系列标签
🚀1.1 input系列标签的基本介绍
♗ 场景:
在网页中显示收集用户信息的表单效果,如:登录页、注册页
♗标签名:input
• input标签可以通过type属性值的不同,展示不同效果
♗ type属性值:
💻代码演示:
<!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>
<!-- 写什么就显示什么 -->
文本框: <input type="text">
<br>
<br>
<!-- 书写的内容都会变成点点显示 -->
密码框: <input type="password">
<br>
<br>
单选框: <input type="radio">
<br>
<br>
多选框: <input type="checkbox">
<br>
<br>
上传文件: <input type="file">
</body>
</html>
💻运行效果:
🚀1.2 input系列标签-文本框
♗ 场景:
在网页中显示输入单行文本的表单控件
♗ type属性值:text
♗ 常用属性:
💻代码演示:
<!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>
<input type="text" placeholder="请输入用户名">
</body>
</html>
💻运行效果:
💡(拓展)value属性和name属性作用介绍
♗value属性:
用户输入的内容,提交之后会发送给后端服务器
♗ name属性:
当前控件的含义,提交之后可以告诉后端发送过去的数据是什么含义
♗ 后端接收到数据的格式是:
name的属性值 = value的属性
🚀1.3 input系列标签-密码框
♗场景:
在网页中显示输入密码的表单控件
♗ type属性值:password
♗ 常用属性(同文本框):
💻代码演示:
<!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>
<input type="password" placeholder="请输入密码">
</body>
</html>
💻运行效果:
♗ 注意点:
- type属性值不要拼错或者多加空格,否则相当于设置了默认值状态:text→文本框
🚀1.4 input系列标签-单选框
♗ 场景:
在网页中显示多选一的单选表单控件
♗ type属性值:radio
♗ 常用属性:
♗ 注意点:
- name属性对于单选框有分组功能
- 有相同name属性值的单选框为一组,一组中只能同时有一个被选中
💻代码演示:
<!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>
性别: <input type="radio" name="sex">男
<input type="radio" name="sex" checked>女
<input type="checkbox" checked>
</body>
</html>
💻运行效果:
🚀1.5 input系列标签-复选框
♗场景:
在网页中显示多选多的多选表单控件
♗ type属性值:checkbox
♗常用属性(同单选框):
🚀1.6 input系列标签-文件选择
♗ 场景:
在网页中显示文件选择的表单控件
♗ type属性值:file
♗ 常用属性:
<!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>
<input type="file" multiple>
</body>
</html>
💻运行效果:
🚀1.7 input系列标签-按钮
♗ 场景:
在网页中显示不同功能的按钮表单控件
♗ type属性值:
♗ 注意点:
- 如果需要实现以上按钮功能,需要配合form标签使用
- form使用方法:用form标签把表单标签一起包裹起来即可
💻代码演示:
<!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>
<form action="">
用户名: <input type="text">
<br>
<br>
密码: <input type="password">
<br>
<br>
<!-- 按钮 -->
<input type="submit" value="免费注册">
<input type="reset">
<input type="button" value="普通按钮">
<!-- 属性 xx="xxx" -->
</form>
</body>
</html>
💻运行效果:
🚀1.8 input系列标签总结
♗ input标签的type属性值:
♗ 注意点:
- 占位符:placeholder
- 如果需要实现单选效果,需要设置相同的name属性值
- 单选框和多选框的默认选中:checked
⚡️2. button按钮标签
♗ 场景:
在网页中显示用户点击的按钮
♗标签名:button
♗ type属性值(同input的按钮系列):
♗ 注意点:
- 谷歌浏览器中button默认是提交按钮
- button标签是双标签,更便于包裹其他内容:文字、图片等
💻代码演示:
<!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>
<button>我是按钮</button>
<button type="submit">提交按钮</button>
<button type="reset">重置按钮</button>
<button type="button">普通按钮, 没有任何功能</button>
</body>
</html>
💻运行效果:
⚡️3. select下拉菜单标签
♗ 场景:
在网页中提供多个选择项的下拉菜单表单控件
♗ 标签组成:
- select标签:下拉菜单的整体
- option标签:下拉菜单的每一项
♗ 常见属性:
- selected:下拉菜单的默认选中
💻代码演示:
<!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>
<select>
<option>北京</option>
<option>上海</option>
<option>广州</option>
<option selected>深圳</option>
</select>
</body>
</html>
💻运行效果:
⚡️4. textarea文本域标签
♗ 场景:
在网页中提供可输入多行文本的表单控件
♗ 标签名:textarea
♗ 常见属性:
- cols:规定了文本域内可见宽度
- rows:规定了文本域内可见行数
♗ 注意点:
- 右下角可以拖拽改变大小
- 实际开发时针对于样式效果推荐用CSS设置
💻代码演示:
<!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>
<textarea cols="60" rows="30"></textarea>
</body>
</html>
⚡️5. label标签
♗ 场景:
常用于绑定内容与表单标签的关系
♗标签名:label
♗使用方法①:
- 使用label标签把内容(如:文本)包裹起来
- 在表单标签上添加id属性
- 在label标签的for属性中设置对应的id属性值
💻代码演示:
<!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>
性别:
<!--使用方法1:-->
<input type="radio" name="sex" id="nan"> <label for="nan">男</label>
</body>
</html>
♗ 使用方法②:
- 直接使用label标签把内容(如:文本)和表单标签一起包裹起来
- 需要把label标签的for属性删除即可
💻代码演示:
<!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>
性别:
<!--使用方法1:-->
<input type="radio" name="sex" id="nan"> <label for="nan">男</label>
<!--使用方法2:-->
<label><input type="radio" name="sex"> 女</label>
</body>
</html>
💻运行效果:
⚡️6. 表单标签-总结
♗ ① input标签不同形态
♗ ② button按钮标签:
♗ ③ select下拉菜单标签:
♗ ④ textarea文本域标签:
♗ ⑤ label标签:
☀️语义化标签
⚡️1. 没有语义的布局标签
🚀1.1 没有语义的布局标签-div和span
♗ 场景:
实际开发网页时会大量频繁的使用到div和span这两个没语义的布局标签
♗ div标签:
一行只显示一个(独占一行)
♗ span标签:
一行可以显示多个
💻代码演示:
<!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>
普通文字
<div>这是div标签</div>
<div>这是div标签</div>
<span>这是span标签</span>
<span>这是span标签</span>
</body>
</html>
💻运行效果:
普通文字
这是div标签
这是div标签
这是span标签 这是span标签
⚡️2. 有语义的布局标签(了解)
♗ 场景:
在HTML5新版本中,推出了一些有语义的布局标签供开发者使用
♗ 标签:
♗ 注意点:
- 以上标签显示特点和div一致,但是比div多了不同的语义
☀️字符实体
⚡️1. HTML中的空格合并现象
♗场景:
如果在html代码中同时并列出现多个空格、换行、缩进等,最终浏览器只会解析出一个空格
⚡️2. 常见字符实体
♗ 场景:在网页中展示特殊符号效果时,需要使用字符实体替代
♗ 结构:
♗ 常见字符实体: