前端开发笔记 | HTML5语义篇

一:前言

本篇是教程篇,包含各个知识点的详细举例和说明。查询标签需前往词典篇 | 点此前往

本系列是为萌新准备的HTML超详细基础笔记,统计了大约400+的知识点和扩展开发经验总结,根据B站教学视频顺序对每个知识点进行了特别排序,可以很好的满足新人的上手需求。如您遇到无法解决的难题或者有对笔记不理解的地方,欢迎进群和我们一起讨论 (九依の小屋) 。当然了,也可以前往[W3SChool] 官方网去了解。 推荐学习网站 |菜鸟教程首页 / 在线编程工具

一起讨论:九依の小屋

二:工具

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
# 常用快捷键​===============================================
# !+Enter:生成HTML头文件
# Lorem:随机生成一句英文
# Ctrl+Shift+/:代码快速注释
# Ait+w:代码快速添加标签
# Shift+Ait+F:代码格式化
# Table+选中代码:代码格式化

# 基础编辑快捷键​===========================================
# |复制/剪切/粘贴行:​Ctrl+C/Ctrl+X (未选中时) //Max系统:Cmd+C/Cmd+X
# |​删除当前行:​Ctrl+Shift+K //Max系统:Cmd+Shift+K
# |​上下移动行:​Alt+↑/↓ //Max系统:Option+↑/↓
# |​上下复制行:​Shift+Alt+↑/↓ //Max系统:Shift+Option+↑/↓
# |​插入新行(上/下):Ctrl+Shift+Enter / Ctrl+Enter //Max系统:Cmd+Shift+Enter / Cmd+Enter
# |​行注释/取消:Ctrl+/ //Max系统:Cmd+/
# |​块注释/取消:Shift+Alt+A //Max系统:Shift+Option+A

# 导航与搜索​==============================================
# |快速打开文件:​Ctrl+P //Max系统:Cmd+P
# |​跳转到行号:Ctrl+G //Max系统:Cmd+G
# |​跳转到符号(类/函数):​Ctrl+Shift+O //Max系统:Cmd+Shift+O
# |​跳转到定义:F12
# |​查看定义(不跳转)​:Alt+F12 //Max系统:Option+F12
# |​全局搜索文本:Ctrl+Shift+F //Max系统:Cmd+Shift+F
# |查找/替换:Ctrl+F / Ctrl+H //Max系统:Cmd+F / Cmd+H
# |​切换已打开文件:Ctrl+Tab

# 代码重构与智能操作​=======================================
# |​重命名符号(变量/函数)​: F2
# |​格式化整个文档: Shift+Alt+F //Max系统:Shift+Option+F
# |​格式化选中代码: Ctrl+K Ctrl+F //Max系统:Cmd+K Cmd+F
# |​快速修复建议: Ctrl+. //Max系统:Cmd+.
# |​选择所有相同变量: Ctrl+F2 //Max系统: Cmd+F2
# |​多光标编辑: Alt+Click 或 Ctrl+Alt+↑/↓ //Max系统:Option+Click 或 Cmd+Option+↑/↓

# 窗口与面板管理​===========================================
# |​切换侧边栏显示: ​Ctrl+B //Max系统:Cmd+B
# |​打开/关闭终端: ​Ctrl+` //Max系统:Cmd+`
# |​新建终端: ​Ctrl+Shift+ ` //Max系统:Cmd+Shift+ `
# |​拆分编辑器: ​Ctrl+\ //Max系统:Cmd+\
# |​切换编辑器组: ​Ctrl+1/2/3 //Max系统:Cmd+1/2/3
# |​全屏模式: ​F11
# |​打开命令面板: ​Ctrl+Shift+P //Max系统:Cmd+Shift+P

# 调试快捷键​===============================================
# |启动/继续调试: F5
# |​停止调试​: Shift+F5
# |​单步进入(函数内部): ​​ F11
# |​单步跳过(不进入函数): ​​ F10
# |​单步跳出(函数返回)​: ​ Shift+F11
# |​切换断点: F9
=============================================================================================================

# HTML-------------------------------------------------------------------------------------------------------
//Other:
# |"{SEO}"指代是"搜素引擎优化",用以优化网页的流量曝光或者利于爬虫爬取以此提升网站的访问数.
# |"{块元素}block-level":独占一行且禁止嵌套,宽高默认为100%| 可以通过"display"进行更改元素类型.
# |"{行内元素}lnline":不独占一行,宽度由内容撑开,无法设置宽高.
# |"{行内块元素}lnline-block":兼具上方两种元素特性,可设置宽高而不强制换行.
# |"{替换元素}":内容由外部元素决定(如img和video等).
# |"{表单元素}":交互控件(如from和input等),部分默认为行内块.

三:教程

字符实体与语义标签

1.字符实体

  • 有些时候,在HTML中不能直接书写一些特殊符号,如:
  • 多个连续的空格(在网页中编写的多个空格默认情况会自动被浏览器解析为一个空格)
  • 比如字母两侧的大于小于号(可能会被认为是标签并解析)

  • 如果我们需要在网页中书写这些特殊的符号,则需要使用html中的实体(转义字符)实体的语法:`&实体的名字;`,如:
 ``空格
>>大于号
&lt;<小于号
&amp;&
&copy;©版权
&reg;®注册商标
&trade;商标
&times;×乘号
&divide;÷除号
&iquest;¿倒问号

2.meta标签

  • 个人理解name里面的值是指定的,然后content里的内容会在根据name中的值发挥不同的作用
  • 以京东网站为例:
1
2
3
4
<meta charset="utf8" version='1'/>
<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=yes"/>
<meta name="description" content="京东JD.COM-专业的综合网上购物商城,销售家电、数码通讯、电脑、家居百货、服装服饰、母婴、图书、食品等数万个品牌优质商品.便捷、诚信的服务,为您提供愉悦的网上购物体验!"/>
<meta name="Keywords" content="网上购物,网上商城,手机,笔记本,电脑,MP3,CD,VCD,DV,相机,数码,配件,手表,存储卡,京东"/>
  • meta主要用于设置网页中的一些元数据,元数据并不是给用户看的
  • charset :指定网页的字符集

  • name :指定的数据的名称
  • keywords:表示网站的关键字,可以同时指定多个关键字,关键字间使用,隔开
  • description:表示网站的描述信息 |
  • content :指定的数据的内容,会作为搜索结果的超链接上的文字显示

3.语义化标签

  • 电脑编辑器都是`gbk`写的,而`vscode`是用`utf-8`打开的---会乱码 | 标签语义 /简单的理解:标签的含义,即:这个标签是用来干嘛的。
  • 这里先介绍几个基本的语义标签,还有些常用的标签放在后面具体讲解:
标签作用描述
块元素 Block Element<h1> <h2> <h3> <h4> <h5> <h6>标题一共有六级标题 从h1 ~ h6重要性递减,h1最重要,h6最不重要 h1在网页中的重要性仅次于title标签 一般情况下一个页面中只会有一个h1 一般情况下标题标签只会使用到h1h3h4h6很少用
<hgroup>标题组多层次的标题。它将一组<h1><h6>元素分组
<p>段落页面中的一个段落。由空行或第一行缩进将相邻的文本块分开
<blockquote>短引文用缩进表示所包含文本。 可以用cite属性表示引文来源,用<cite>元素表示来源的文本表述
行内元素 Inline Element<q>长引文用一个简短的内联引号包围文本。 大多数浏览器通过在文本周围加上引号来实现。 该元素用于不需要段落分隔的短引文;
<br>换行
<em>强调表示强调作用。<em>元素可以嵌套,每一级嵌套表示更高的强调程度 <i>元素效果与它相同,不过<i>不属于语义标签
<strong>重要表示重要性、严肃性或紧迫性。浏览器通常以粗体字呈现内容 <b>元素效果与它相同,不过<b>不属于语义标签

注意:<em> 标签不只是单纯的用于倾斜文本,其核心的意义在于对元素进行强调!所以在后期的开发中可以把一些特殊性、强调性的元素放在 em 标签中,然后再对 em 这个盒子进行样式设置,这比把其放入其他盒子(如:span)中要更合理,同理 <strong> 标签页适合放一些重点强调的元素。

1
2
3
4
5
6
<h1>一级标题</h1>
<h2>二级标题</h2>
<h3>三级标题</h3>
<h4>四级标题</h4>
<h5>五级标题</h5>
<h6>六级标题</h6>
  • 标签语义:作为标题使用,并且依据重要性递减。
  • 特点:
  • 加了标题的文字会自动加粗,字号也会依次变大
  • 一个标题就独占一行,同一行标题后不会再放置其他任何内容(后期可以通过 CSS 修改)

    级别越大的标题标签,对网页元素的强调性越强,同时也和浏览器 SEO 优化有关。

    故:标题标签不得滥用,要用在合适的地方!

  • HTML5 提供的新语义元素有:
标签作用描述
<header>页眉介绍性的内容
<footer>页脚通常包含有关作者的信息、版权或文件链接
<nav>导航链接可以是当前文档内的,也可以是到其他文档的。常见例子是菜单、目录和索引
<main>文档主内容中心主题直接相关或扩展的内容
<article>文章自成一体,独立分发,可重复使用
<section>文档中的节没有一个更具体的语义元素来代表
<aside>页面内容以外的内容其内容与文档的主要内容只有间接的关系。经常以边栏或呼出框的形式出现
<mark>重要或强调的文本为参考或记事目的而被标记或突出的文本,表明其相关性和重要性
<summary><details> 标题<details>指定一个摘要、标题或图例。点击<summary>可以切换<details>打开和关闭
<details>用户能够查看或隐藏的额外细节其中的信息只有被切换到 “打开 “状态时才可见。必须使用<summary>提供一个摘要或标签
<figure>自包含内容独立的内容,用<figcaption>元素指定一个可选的标题。比如图示、图表、照片、代码清单等
<figcaption><figure> 的标题描述其父元素
<time>定义日期/时间可能包括datetime属性,将日期翻译成机器可读的格式,以便获得更好的搜索引擎结果或自定义功能。如提醒
  • 这些新语义标签在视觉效果上基本上没有什么区别

4.内容修正

  • 浏览器在解析网页时,会自动对网页中不符合规范的内容进行修正,比如:
  • 标签写在了根元素的外部

  • 元素中嵌套了块元素
  • 根元素中出现了除headbody以外的子元素

  • 这个通过浏览器中的`查看网页源代码`并不能看到效果,但是使用F12进行`开发者调试`时是能够看到上述几种情况被修正的结果。
  • 不过虽然浏览器能够对不规范的页面内容进行修正,还是不建议编写不规范的代码,因为这对后期代码维护或团队代码协作将是非常不好的后果和体验。

5.布局标签

  • 结构化语义标签
  • header表示网页的头部(页眉)
  • main表示网页的主体部分(一个页面中只会有一个main)
  • footer表示网页的底部(页脚)
  • nav表示网页中的导航
  • aside和主体相关的其他内容(侧边栏)
  • article表示一个独立的文章
  • section表示一个独立的区块,上边的标签都不能表示时使用section|

注意:

  • 这种语义化标准主要是针对搜索引擎的
  • 这些新标签页面中可以使用多次
  • 在 IE9 中,需要把这些元素转换为块级元素
  • 其实,我们移动端更喜欢使用这些标签
  • div 块元素,没有任何的语义,就用来表示一个区块。目前来讲,div还是主要的布局元素
  • span 行内元素,没有任何的语义,一般用于在网页中选中文字
  • <div><span>` 是没有语义的,它们就是两种盒子,用来对网页进行布局和装其他内容。
1
2
<div>这是头部</div>
<span>今日价格</span>

div 是 division 的缩写表示:分割、分区。

span 意为:跨度、跨距。

  • 特点:
  • &lt;div> 标签用来布局,一行只能放一个 &lt;div>,大盒子

  • &lt;span> 标签用来布局,一行上可以放多个 &lt;span>,小盒子

  • 说明:后期可以通过 CSS 将 div 与 span 之间的特性相互转换。
  • 拓展: `span` 标签不单单是用于布局,对于一些需要单独修饰和设置的元素,可以将其用 `span` 标签嵌套起来,然后就可以单独对其进行设置(比如:在一个 p 标签的段落中要对其中某一句话单独设置样式,那么就可以用 span 将这句话单独嵌套起来,这样就方便对其单独设置样式还不会影响段落中的其他内容,这其实也是利用了 span 一行可以放置多个盒子的特性),不过对于特殊且具有强调性的元素建议使用 `em`,对于重点强调但不特殊的的元素建议使用 `strong`。

6.段落和换行标签

  • 在网页中,要把文字有条理地显示出来,就需要将这些文字分段显示,在 HTML 标签中,<p> 标签用于定义段落,它可以将整个网页分为若干个段落。</p>
1
<p>我是一个段落标签</p>

单词 paragraph 的缩写,意为:段落。

  • 便签语义:可以把 HTML 文档分割为若干段落。
  • 特点:
  • 文本在一个段落中会根据浏览器窗口的大小自动换行
    对于中文段落来说无论如何都会自动换行,但是对于英文段落来说如果字母是连续的(aaa…),那么浏览器会认为该段落整体都是一个字母不会自动换行,要想英文段落自动换行字母之间得有空格。
  • 段落和段落之间保有空隙(段间距)
  • 同一段落里的不同行文字之间也有一定的空隙(行间距)
  • 在 HTML 中,一个段落中的文字会从左到右依次排列,直到浏览器窗口的右端,然后才自动换行。
  • 如果希望某段文本强制换行显示,就需要使用换行标签 `
    `。
1
<br>

单词 break 的缩写,意为:打断、换行。

  • 标签语义:强制换行。
  • 特点:
  • &lt;br> 是个单标签
  • &lt;br><br>` 标签只是简单地开始新的一行,跟段落不一样,所以不会产生段间距
  • 分割线标签:`<hr>`。
1
2
<hr>
<!-- 某些时候需要对内容块进行分割时会用到分割线标签 -->

注意:实际开发中并不常用 hr 作为分割线,而是使用 CSS 盒子模型中的边框来实现分割线效果,或是利用一个空盒子设置长宽高及背景颜色来实现分割线效果。

7.列表

  • 表格是用来显示数据的,那么列表就是用来布局的.
  • 列表最大的特点就是:整齐、整洁、有序、它作为布局会更加自由和方便。
  • 在实际开发中凡是遇到排列整齐的简洁内容,都可以使用列表来进行布局。
  • 合理的使用列表布局可以有效提高 SEO。
  • 根据使用情景不同,列表可以分为三大类:`无序列表`、`有序列表` 和 `自定义列表`。
标签名定义说明
<ul> </ul>无序标签里面只包含 li,没有顺序,使用较多,li 里面可以包含任何标签
<ol> </ol>有序标签里面只包含 li,有顺序,使用相对较少,li 里面可以包含任何标签
<dl> </dl>自定义标签里面只能包含 dt 和 dd,dt 和 dd 里面可以放任何标签,dd 一般作为对 dt 的细分描述

7.1 无序列表

  • `<ul>` 标签表示 HTML 页面中项目的无序列表,一般会以项目符号呈现列表项,而列表项使用 `<li>` 标签定义(开发中经常使用)。
  • 无序列表的基本语法格式如下:
1
2
3
4
5
6
<ul>
<li>列表项1</li>
<li>列表项2</li>
<li>列表项3</li>
...
</ul>
  • 无序列表的各个列表项之间没有顺序级别之分,是并列的
  • &lt;ul> &lt;/ul> 中只能嵌套 &lt;li> &lt;/li>,直接在 &lt;ul> &lt;/ul> 标签中输入其他标签或者文字的做法是不被允许的,列表中的任何内容都应该放在 li
  • &lt;li>&lt;/li> 之间相当于一个容器,可以容纳所有的元素
  • 无序列表会带有自己的样式属性(比如圆点),但在实际开发中,我们会使用 CSS 来设置

    附:去除 li 前符号的方法:style="list-style: none;"

7.2 有序列表

  • 有序列表即为有序排列顺序的列表,其各个列表项会按照一定的顺序排列定义(开发中不太常用)。
  • 在 HTML 标签中,`
      ` 标签用于定义有序列表,列表排序以数字来显示,并且使用 `
    1. ` 标签来定义列表项。
  • 有序列表的基本语法格式如下:
1
2
3
4
5
6
<ol>
<li>列表项1</li>
<li>列表项2</li>
<li>列表项3</li>
...
</ol>
  • &lt;ol> &lt;/ol> 中只能嵌套 &lt;li> &lt;/li>,直接在 &lt;ol> &lt;/ol> 标签中输入其他标签或者文字的做法是不被允许的
  • &lt;li>&lt;/li> 之间相当于一个容器,可以容纳所有的元素
  • 有序列表会带有自己样式属性(比如序号),但在实际使用时,我们会使用 CSS 来设置

附:去除 li 前符号的方法:style="list-style: none;"

7.3 自定义列表

  • 自定义列表的使用场景:
  • 自定义列表常用于对术语或名词进行解释、描述和展开,定义列表的列表项前没有任何项目符号(开发中常用)。
  • 在 HTML 标签中,`<dl>` 标签用于定义描述列表(或定义列表),该标签会与 `<dt>`(定义项目/名字)和 `<dd>`(描述每一个项目/名字)一起使用。
  • 其基本语法如下:
1
2
3
4
5
<dl>
<dt>名词1</dt>
<dd>名词1解释1</dd>
<dd>名词1解释2</dd>
</dl>
  • &lt;dl> &lt;/dl> 里面只包含 &lt;dt>&lt;dd>
  • &lt;dt>&lt;dd> 个数没有限制,经常是一个 &lt;dt> 对应多个 &lt;dd>

8.超链接

  • 在 HTML 标签中,`<a>` 标签用于定义超链接,作用是从一个页面链接到另一个页面。
  • (1)链接的语法格式
1
<a href="跳转目标" target="目标窗口的弹出方式">文本、图像或其他内容</a>

单词 anchor 的缩写,意为:锚。

  • 两个属性的作用如下:
属性作用
href用于指定链接目标的 url 地址,(必须属性)当标签应用 href 属性时,它就具有了超链接的功能
target用于指定链接页面的打开方式,其中 _self 在当前页面打开的方式(为默认值),_blank 在新窗口中打开的方式
  • (2)链接分类
  • 外部链接:例如:`<a href="http://www.baidu.com">百度</a>`
  • 内部链接:网站内部页面之间相互链接,直接链接内部页面名称即可,例如: `<a href="index.html">首页</a>`
    • 当我们需要跳转一个服务器内部的页面时,一般我们都会使用相对路径,会以./../开头
    • ./ 表示当前文件所在目录,可以省略不写
    • ../表示当前文件所在目录的上一级目录
  • 空链接:如果当时没有确定链接目标时, `<a href="javascript:void(0)">首页</a>"`,当用户点击链接时,void(0) 计算为 0,但 Javascript 上没有任何效果
  • 下载链接:如果 href 里面地址是一个文件或者压缩包(前提:路径包含文件类型后缀名,如:`.exe`、`.zip` 等),便会下载这个文件
  • 网页元素链接:在网页中的各种网页元素,如:文本、图像、表格、音频、视频等都可以添加超链接
  • 锚点链接:点击链接,可以快速定位到当前页面中的某个位置
    • 在链接文本的 href 属性中,设置属性值的 #名字 的形式,如:&lt;a href="#two">第2集&lt;/a>
    • 找到目标位置标签(此处以 h3 标签为例),里面添加一个 id属性="刚才的名字",如:&lt;h3 id="two">第2集介绍&lt;/h3>
    • &lt;a href="#">&lt;/a> 默认定位到页面顶部
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    49
    50
    51
    52
    53
    54
    55
    56
    57
    58
    59
    60
    61
    62
    63
    <p> 汉皇重色思倾国,御宇多年求不得。</p>
    <p> 杨家有女初长成,养在深闺人未识。 </p>
    <p> 天生丽质难自弃,一朝选在君王侧。 </p>
    <p><a id="Anchor1" href="#Anchor2"> 回眸一笑百媚生,六宫粉黛无颜色。</a></p>
    <p> 春寒赐浴华清池,温泉水滑洗凝脂。 </p>
    <p> 侍儿扶起娇无力,始是新承恩泽时。 </p>
    <p> 云鬓花颜金步摇,芙蓉帐暖度春宵。 </p>
    <p> 春宵苦短日高起,从此君王不早朝。 </p>
    <p> 承欢侍宴无闲暇,春从春游夜专夜。 </p>
    <p><a id="Anchor2" href="#Anchor3"> 后宫佳丽三千人,三千宠爱在一身。</a></p>
    <p> 金屋妆成娇侍夜,玉楼宴罢醉和春。 </p>
    <p> 姊妹弟兄皆列土,可怜光彩生门户。 </p>
    <p> 遂令天下父母心,不重生男重生女。 </p>
    <p> 骊宫高处入青云,仙乐风飘处处闻。 </p>
    <p> 缓歌慢舞凝丝竹,尽日君王看不足。 </p>
    <p> 渔阳鼙鼓动地来,惊破霓裳羽衣曲。 </p>
    <p> 九重城阙烟尘生,千乘万骑西南行。 </p>
    <p> 翠华摇摇行复止,西出都门百余里。 </p>
    <p> 六军不发无奈何,宛转蛾眉马前死。 </p>
    <p> 花钿委地无人收,翠翘金雀玉搔头。 </p>
    <p> 君王掩面救不得,回看血泪相和流。 </p>
    <p> 黄埃散漫风萧索,云栈萦纡登剑阁。 </p>
    <p> 峨嵋山下少人行,旌旗无光日色薄。 </p>
    <p> 蜀江水碧蜀山青,圣主朝朝暮暮情。 </p>
    <p> 行宫见月伤心色,夜雨闻铃肠断声。 </p>
    <p> 天旋地转回龙驭,到此踌躇不能去。 </p>
    <p> 马嵬坡下泥土中,不见玉颜空死处。 </p>
    <p> 君臣相顾尽沾衣,东望都门信马归。 </p>
    <p> 归来池苑皆依旧,太液芙蓉未央柳。 </p>
    <p> 芙蓉如面柳如眉,对此如何不泪垂。 </p>
    <p> 春风桃李花开夜,秋雨梧桐叶落时。 </p>
    <p> 西宫南苑多秋草,落叶满阶红不扫。 </p>
    <p> 梨园弟子白发新,椒房阿监青娥老。 </p>
    <p> 夕殿萤飞思悄然,孤灯挑尽未成眠。 </p>
    <p><a id="Anchor3" href="#Anchor4"> 迟迟钟鼓初长夜,耿耿星河欲曙天。 </a></p>
    <p> 鸳鸯瓦冷霜华重,翡翠衾寒谁与共。 </p>
    <p> 悠悠生死别经年,魂魄不曾来入梦。 </p>
    <p> 临邛道士鸿都客,能以精诚致魂魄。 </p>
    <p> 为感君王辗转思,遂教方士殷勤觅。 </p>
    <p> 排空驭气奔如电,升天入地求之遍。 </p>
    <p> 上穷碧落下黄泉,两处茫茫皆不见。 </p>
    <p> 忽闻海上有仙山,山在虚无缥渺间。 </p>
    <p> 楼阁玲珑五云起,其中绰约多仙子。 </p>
    <p> 中有一人字太真,雪肤花貌参差是。 </p>
    <p> 金阙西厢叩玉扃,转教小玉报双成。 </p>
    <p> 闻道汉家天子使,九华帐里梦魂惊。 </p>
    <p> 揽衣推枕起徘徊,珠箔银屏迤逦开。 </p>
    <p> 云鬓半偏新睡觉,花冠不整下堂来。 </p>
    <p><a id="Anchor4" href="#Anchor5"> 风吹仙袂飘飖举,犹似霓裳羽衣舞。 </a></p>
    <p> 玉容寂寞泪阑干,梨花一枝春带雨。 </p>
    <p> 含情凝睇谢君王,一别音容两渺茫。 </p>
    <p> 昭阳殿里恩爱绝,蓬莱宫中日月长。 </p>
    <p> 回头下望人寰处,不见长安见尘雾。 </p>
    <p> 惟将旧物表深情,钿合金钗寄将去。 </p>
    <p> 钗留一股合一扇,钗擘黄金合分钿。 </p>
    <p> 但令心似金钿坚,天上人间会相见。 </p>
    <p> 临别殷勤重寄词,词中有誓两心知。 </p>
    <p> 七月七日长生殿,夜半无人私语时。 </p>
    <p><a id="Anchor5" href="#Anchor6"> 在天愿作比翼鸟,在地愿为连理枝。 </a></p>
    <p> 天长地久有时尽,此恨绵绵无绝期。 </p>

    <!-- Heading to link to -->
    <a href="#">回到顶部</a>

    |

9.路径

9.1 相对路径

  • 相对路径:以引用文件所在位置为参考基础,而建立出目录路径。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<!--           09.相对路径.html
当我们需要跳转一个服务器内部的页面时,一般我们都会使用相对路径
相对路径都会使用.或..开头
./
../
./可以省略不写,如果不写./也不写../则就相当于写了./

./ 表示当前文件所在的目录
- 在这里当前页面就是 09.相对路径.html
- ./就等于 09.相对路径.html 所在的目录 path =( path/09.相对路径.html)

../ 表示当前文件所在目录的上一级目录
-->
<a href="./target.html">超链接1</a>
<br><br>
<a href="../07.列表.html">超链接2</a>
<br><br>
<a href="./inner/target2.html">超链接3</a>
<br><br>
<a href="../outer/target3.html">超链接4</a>

<!-- 绝对路径 从项目根目录开始 以/开头-->
<a href="/01_introduce/path/inner/target2.html" target="_blank">超链接</a>

9.2 绝对路径

  • 绝对路径:指目录下的绝对位置,直接到达目的位置,通常是从盘符开始的路径。
  • 如 Windows 系统的绝对路径:`D:\web\img\logo.png`

9.3 网络地址

https://github.com/JERRY-Z-J-R/JERRY-Z-J-R/blob/main/mark-img/readme.gif

10.图片

10.1 基本使用

  • 在 HTML 标签中,`dl>img>` 标签用于定义 HTML 页面中的图像。
1
<img src="图像URL">

单词 image 的缩写,意为图像。

  • `src` 是 `dl>img>` 标签的必须属性,它用于指定图像文件的路径和文件名。
  • `URL` 是 `统一资源定位符`(通俗理解:地址、网址)。
  • 所谓属性:简单理解就是属于这个图像标签的特性。
  • 图像标签的其他属性:
属性属性值说明
src图片路径必须属性
alt文本替换文本,图像显示失败时显示(为了提高 SEO 及适配屏幕阅读器,建议都把 alt 写上)
title文本提示文本,鼠标放到图片上,显示的提示文字
width像素设置图像的宽度(了解,后面通过 CSS 设置)
height像素设置图像的高度(了解,后面通过 CSS 设置)
border像素设置图像的边框粗细(了解,后面通过 CSS 设置)
  • 图像标签的注意点:
  • 图像标签可以同时拥有多个属性(其它标签也是同理)

  • 属性之间不分先后顺序,标签名与属性、属性与属性之间均以空格分开(其它标签也是同理)
  • 属性均采取键值对**的格式,即:key="value" 的格式,属性="属性值"
  • 设置图像的宽度与高度时:一般设置其中之一便可,另外一个会自动按比例适配
  • 设置宽高时,可以使用百分数作为值,此时图片大小会以当前父元素的大小为基础进行比例缩放,这样做的好处在于当父元素改变大小时,图片也会随比例同等缩放

10.2 图片格式

10.2.1 jpeg(jpg)

  • 支持的颜色比较丰富
  • 不支持透明效果
  • 不支持动图
  • 一般用来显示照片c

10.2.2 gif

  • 支持的颜色比较单一
  • 支持简单透明
  • 支持动图

10.2.3 png

  • 支持的颜色丰富
  • 支持复杂透明
  • 不支持动图
  • 专为网页而生

10.2.4 webp

  • 这种格式是谷歌新推出的专门用来表示网页中的图片的一种格式
  • 具备其他图片格式的所有优点,而且文件还特别的小
  • 缺点:兼容性不好

10.2.5 base64

  • 将图片使用base64编码,这样可以将图片转换为字符,通过字符的形式来引入图片
  • 图片格式的选择
1
<img width="300" src="" />
  • 图片效果一样的,选文件小的
  • 图片效果不一样的,选图片效果好的
  • 尽可能的兼顾和平衡图片效果和文件大小

11.内联框架

  • 内联框架`iframe`,用于向当前页面中引入一个其他页面,
  • src指定要引入的网页的路径

  • frameborder指定内联框架的边框

  • 举例:
1
<iframe src="https://www.qq.com" width="800" height="600" frameborder="0"></iframe>

|

  • 设置高度与宽度
  • `height` 和 `width` 属性用来定义 iframe 标签的高度与宽度。
  • 属性默认以像素为单位,但是你可以指定其按比例显示(如:"70%")。
1
<iframe height="500px" src="https://www.bilibili.com/" width="70%"></iframe>

|

  • 提示:您可以把需要的文本放置在 `>iframe>` 和 `>/iframe>` 之间,这样就可以应对不支持 `>iframe>` 的浏览器。
  • 提示:使用 CSS 为 `>iframe>`(包括滚动条)定义样式。
  • 使用 CSS 隐藏 `>iframe>` 滚动条
  • 遮掉 iframe 滚动条:
1
2
3
<div style="width: 400px; overflow: hidden">
<iframe height="480" src="https://www.runoob.com" width="415">您的浏览器不支持</iframe>
</div>
  • 新选择器原生移除滚动条:
1
2
3
4
5
6
7
8
<!-- 此方法目前暂不推荐使用 -->
<head>
<style>
iframe::-webkit-scrollbar {
display: none;
}
</style>
</head>
  • 通过`iframe`的方式引入视频。以某艺为例,提供了视频链接的HTML代码和通用代码

|

1
2
<iframe    src="http://open.iqiyi.com/developer/player_js/coopPlayerIndex.html?vid=0c53ddd55f262c6d416afa9d1f49dc55&tvId=1008748400&accessToken=2.ef9c39d6c7f1d5b44768e38e5243157d&appKey=8c634248790d4343bcae1f66129c1010&appId=1368&height=100%&width=100%"
frameborder="0" allowfullscreen="true" width="100%" height="100%"></iframe>

12.音视频

12.1 音频

  • HTML5 在不使用插件的情况下,也可以原生的支持音频格式文件的播放。当然,支持的格式是有限的。
  • 当前 `>audio>` 元素支持三种音频格式:尽量使用 mp3 格式。

|

  • `audio`标签用来向页面中引入一个外部的音频文件
  • 音视频文件引入时,默认情况下不允许用户自己控制播放停止
  • 属性:
  • controls是否允许用户控制播放

  • autoplay音频文件是否自动播放
    • 如果设置了autoplay,则音乐在打开页面时会自动播放
    • 但是目前来讲大部分浏览器都不会自动对音乐进行播放
  • loop音乐是否循环播放

  • 语法:
1
<audio src="文件地址" controls="controls"></audio>
1
<audio src="./source/audio.mp3" controls autoplay loop></audio>

|

  • 常见属性:

|

12.2 source

  • 除了通过`src`属性来指定外部文件的路径以外,还可以通过``元素来指定文件的路径
1
2
3
4
5
<audio controls="controls">
<source src="happy.mp3" type="audio/mpeg">
<source src="happy.ogg" type="audio/ogg">
您的浏览器暂不支持 <audio> 标签。
</audio>

12.3 视频

  • HTML5 在不使用插件的情况下,也可以原生的支持视频格式文件的播放。当然,支持的格式是有限的。
  • 当前 `>video>` 元素支持三种视频格式:尽量使用 mp4 格式。

|

  • 使用`video`标签来向网页中引入一个视频,使用方式和`audio`基本上是一样的
  • 语法:
1
<video src="文件地址" controls="controls"></video>
1
2
3
4
5
<video controls="controls" width="300"> 
<source src="move.ogg" type="video/ogg">
<source src="move.mp4" type="video/mp4">
您的浏览器暂不支持 <video> 标签播放视频
</ video >

|

  • 常见属性:

|

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>HTML5新增视频标签</title>
<style>
video {
width: 100%;
}
</style>
</head>
<body>
<video src="media/mi.mp4" autoplay="autoplay" muted="muted" loop="loop" poster="media/mi9.jpg"></video>
</body>
</html>

|

12.4 多媒体标签总结

  • 音频标签和视频标签使用方式基本一致
  • 浏览器支持情况不同
  • 谷歌浏览器把音频和视频自动播放禁止了
  • 我们可以给视频标签添加 muted 属性来静音播放视频,音频不可以(可以通过 JavaScript 解决)
  • 视频标签是重点,我们经常设置自动播放,不使用 controls 控件,循环和设置大小属性