Correcting teacher:天蓬老师
Correction status:qualified
Teacher's comments:非常棒
[toc]
文本:用户看到的网页文本,例如新闻,电话等
其它资源:如图片,视频,音频,CSS 样式表,JS 脚本等
标记:对文本以及引用文件的正确描述
有多种编辑器可以实现网页,目前主流的语言是 HTML 5,后续课程学习也用这个。
术语 | 描述 |
---|---|
超文本 | 是指包含有超链接的文本 |
标记 | 就是用来描述内容的固定标签 |
语言 | html 并不编程语言,只是书写 html 文档的工具 |
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>小树之家</title>
</head>
<body>
<!-- 页面主体内容 -->
<h2>欢迎来到幸福小屋</h2>
</body>
</html>
主要分为头部和主体 两部分,body为主体部分。
代码 | 解析 |
---|---|
<!DOCTYPE html> |
通知浏览器这是一个 HTML5 文档,应始终写在第一行 |
<html>...</html> |
根标签,或叫根元素,整个 hmtl 文档内容都必须写到这对标签中 |
<html lang="en"> |
通知搜索引擎 html 文档使用的编写语言,如果是中文建议改成<html lang="zh-CN"> |
<head>...</head> |
供浏览器和搜索引擎使用,描述字符编码集,视口与页面标题,用户并不感兴趣 |
<meta> |
设置页面元素数据, 所谓元数据, 就是描述某种特定信息的数据 |
<meta charset="UTF-8"> |
通知浏览器 html 文档编写语言所属的字符编码集,最流行的是UTF-8 ,已成行业标准 |
<meta name="viewport" content="..." /> |
下面三行是对它的解读 |
name="viewport" |
设置视口(即可视区屏幕)如何显示这个页面, 例如是否允许缩放这个页面 |
width=device-width |
页面宽度应该与显示设备的宽度相匹配,类似还有device-height 表示设备的屏幕高度 |
initial-scale=1.0 |
设置页面初始绽放比例,1.0 表示原样 1:1 显示,不允许有任何绽放 |
<title> |
显示在浏览器标签上的文本, 指定当前页面的标题, 这个标签对 SEO 非常重要 |
<body>...</body> |
页面主体内容,允许或希望用户的内容都应该写到这里,用户也只对这里的内容感兴趣 |
<!-- 注释内容 -> |
注释用来描述标签功能或用途,它的内容不要出现在显示的网页中, 只会出现在 html 源代码中 |
<h2>PHP中文网欢迎您...</h2> |
浏览器渲染这个 html 文档时,最终只会呈现这个标题内容与效果,并不显示标签<h2> |
编写 html 文档的标签字符不区分大小写, 但是推荐全部使用小写字母
元素 | 标签 | 语法 | 描述 | |
---|---|---|---|---|
非空元素 | 双标签 | <p>学习让我变得更强大</p> |
<起始标签>元素内容</结束标签> |
|
空元素 | 单标签 | `<img src="..." alt=""> | <link>` | <标签> |
空元素也有使用双标签描述的,如
<script>|<video>|<br>...
属性名="属性值"
,属性名推荐只使用小写字母,属性值推荐加上双引号<input type="password" maxlength="20" placeholder="至少8个字符" required>
序号 | 值类型 | 描述 |
---|---|---|
1 | 字符串 | <p class="active">...</p> |
2 | 预定义值 | <input type="text"> |
3 | 指定格式 | <a href="https://php.cn">...</a> |
4 | 数值 | <table width="200">...</table> |
5 | 布尔值 | <input type="email" required> |
布尔属性的值是可选的, 只要元素中出现该属性,表示它取真值
序号 | 属性名 | 描述 | 举例 |
---|---|---|---|
1 | id |
元素的唯一标识 | <div id="wrap">...</div> |
2 | class |
给元素添加类样式 | <div class="box">...</div> |
3 | style |
设置当前元素样式 | <div style="...">...</div> |
这几个属性,几乎可以添加到任何元素上
demo2.html
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>元素的标签,属性和值,正确的嵌套关系</title>
</head>
<body>
<!-- 元素之间应该保持正确的嵌套 -->
<form action="">
<div>
<label for="email">邮箱:</label>
<!-- 元素值: 预定义值, 指定值, 布尔值,数值 -->
<input type="email" name="email" id="email" maxlength="100" required />
</div>
<div>
<label for="password">密码:</label>
<input
type="password"
name="password"
id="papassword"
placeholder="至少8位"
required
/>
</div>
<div>
<button>提交</button>
</div>
</form>
</body>
</html>
<
,>
,&
等字符具有特殊意义,需要转义后才允许添加到 html 文档& + 字符实体名称 + ;
, 如<
,使用: <
表示Unicode
极大的缓解了特殊字符的问题,推荐将文档编码设置为utf-8
<head> <mata charset="UTF-8"> </head>
序号 | 字符 | 描述 | 转义字符 | 实体编号 |
---|---|---|---|---|
1 | ' ' |
空格 | nbsp; |
|
2 | < |
小于 | < |
< |
3 | > |
大于 | > |
> |
4 | & |
&符号 |
& |
& |
5 | " |
双引号 | " |
" |
6 | © |
版权 | © |
© |
7 | ® |
已注册商标 | ® |
® |
8 | × |
乘号 | × |
× |
9 | ÷ |
除号 | ÷ |
÷ |
chapter1/demo1.html
.html
, 不要用.htm
-
,而不是下划线_
分隔多个单词http://模式/主机名/路径/文件名
序号 | 名称 | 描述 | 举例 |
---|---|---|---|
1 | 模式 | 也称”协议”,浏览器如何访问这个文件 | http ,https ,ftp ,mailto … |
2 | 主机名 | 使用”域名”或”IP”表示 | https://www.php.cn/ ,或者http://127.0.0.1/ |
3 | 路径 | 使用一个或多个正斜线分割的字符串 | public/admin |
4 | 文件名 | 最后一个路径后面的,带有扩展名的文档 | ablut.html |
如果 URL 是以路径分隔符
/
结尾, 则启用默认文件名,如index.html
序号 | 使用场景 | 举例 |
---|---|---|
1 | 被引用目标与当前位置无关 | http://php.cn/courses/123.html |
2 | 引用其它服务器上的文件 | https://www.php.net/manual/zh/ |
序号 | 使用场景 | 举例 |
---|---|---|
1 | 引用同一目录下文件 | 直接写文件名,如demo2.html |
2 | 引用子目录下文件 | 目标文件前带上子目录名,使用目录分隔符/ 连接,如chapter2/demo2.html |
3 | 引用上层目录的文件 | 文件名前添加二个点,同样使用目录分隔符/ 连接,允许逐级向上查询,如../../demo2.html |
4 | 根路径/ |
为防止过多层级的向上递归查询,可以从当前服务器根目录开始查询,如/admin/books/chapter2/ |
访问同一个网站的文件,应该始终坚持使用相对 URL 地址
序号 | 优点 | 描述 |
---|---|---|
1 | 更直观 | 对于一篇文章<article> 标签,显然要比使用<div class="article"> |
2 | SEO 优化 | 搜索引擎更加喜欢你的网页,有利于 SEO, 得升关键词优化与排名 |
3 | 代码更少 | 提高加载速度,也方便代码维护与样式控制 |
4 | 无障碍支持 | 例如视力受损使用的屏幕阅读器, 语义化就非常重要了 |
本次课程老师可谓从零基础出发,比较详细地主要讲解了html相关内容,虽然以前接触过这些,但对于较长时间没有动手实操的我来说,也非常有必要从最基础的概念开始重新梳理一遍,很多地方还有了新的体会:
1、细致解读了html的文件结构,包括头部和主体及相关知识点;
2、讲解了元素,标签、属性和值,我感觉老师画的解说图很直观、很实用,便于记忆;
3、学习了html中的转义字符的使用等;
4、加深了URL相关知识的理解,并且能结合实例,非常好;
5、希望老师推荐你在用的录播软件和教鞭软件,实际工作中自己可能也会用到。