02 【字符实体与语义标签(上)】

2.字符实体与语义标签上

2.1字符实体

有些时候,在HTML中不能直接书写一些特殊符号,如:

  • 多个连续的空格(在网页中编写的多个空格默认情况会自动被浏览器解析为一个空格)

  • 比如字母两侧的大于小于号(可能会被认为是标签并解析)

如果我们需要在网页中书写这些特殊的符号,则需要使用html中的实体(转义字符)实体的语法:&实体的名字;,如:

实体名称显示结果描述
 ``空格
>>大于号
&lt;<小于号
&amp;&
&copy;©版权
&reg;®注册商标
&trade;商标
&times;×乘号
&divide;÷除号
&iquest;¿倒问号

更多的字符实体,可参考:HTML 字符实体HTML ISO-8859-1 参考手册

2.2meta标签

个人理解name里面的值是指定的,然后content里的内容会在根据name中的值发挥不同的作用

以京东网站为例,右键单击,选择查看网页源代码

<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:表示网站的描述信息
      image-20220701132327433
  • content :指定的数据的内容,会作为搜索结果的超链接上的文字显示

  • content :指定的数据的内容,会作为搜索结果的超链接上的文字显示

2.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> 标签页适合放一些重点强调的元素。

<h1>一级标题</h1>
<h2>二级标题</h2>
<h3>三级标题</h3>
<h4>四级标题</h4>
<h5>五级标题</h5>
<h6>六级标题</h6>

img

**标签语义:**作为标题使用,并且依据重要性递减。

特点:

  • 加了标题的文字会自动加粗,字号也会依次变大
  • 一个标题就独占一行,同一行标题后不会再放置其他任何内容(后期可以通过 CSS 修改)

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

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

HTML5 提供的新语义元素有

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

这些新语义标签在视觉效果上基本上没有什么区别

2.4内容修正

浏览器在解析网页时,会自动对网页中不符合规范的内容进行修正,比如:

  • 标签写在了根元素的外部

  • <p>元素中嵌套了块元素

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

这个通过浏览器中的查看网页源代码并不能看到效果,但是使用F12进行开发者调试时是能够看到上述几种情况被修正的结果。

不过虽然浏览器能够对不规范的页面内容进行修正,还是不建议编写不规范的代码,因为这对后期代码维护或团队代码协作将是非常不好的后果和体验。

2.5布局标签

结构化语义标签

  • header表示网页的头部(页眉)

  • main表示网页的主体部分(一个页面中只会有一个main)

  • footer表示网页的底部(页脚)

  • nav表示网页中的导航

  • aside和主体相关的其他内容(侧边栏)

  • article表示一个独立的文章

  • section表示一个独立的区块,上边的标签都不能表示时使用section

image-20220731131003268

注意:

  • 这种语义化标准主要是针对搜索引擎的
  • 这些新标签页面中可以使用多次
  • 在 IE9 中,需要把这些元素转换为块级元素
  • 其实,我们移动端更喜欢使用这些标签
  • div 块元素,没有任何的语义,就用来表示一个区块。目前来讲,div还是主要的布局元素
  • span 行内元素,没有任何的语义,一般用于在网页中选中文字

<div><span> 是没有语义的,它们就是两种盒子,用来对网页进行布局和装其他内容。

<div>这是头部</div>
<span>今日价格</span>

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

span 意为:跨度、跨距。

特点:

  • <div> 标签用来布局,一行只能放一个 <div>大盒子
  • <span> 标签用来布局,一行上可以放多个 <span>小盒子

**说明:**后期可以通过 CSS 将 div 与 span 之间的特性相互转换。

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

2.6段落和换行标签

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

<p>我是一个段落标签</p>

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

**便签语义:**可以把 HTML 文档分割为若干段落。

特点:

  • 文本在一个段落中会根据浏览器窗口的大小自动换行

    对于中文段落来说无论如何都会自动换行,但是对于英文段落来说如果字母是连续的(aaa…),那么浏览器会认为该段落整体都是一个字母不会自动换行,要想英文段落自动换行字母之间得有空格。

  • 段落和段落之间保有空隙(段间距)

  • 同一段落里的不同行文字之间也有一定的空隙(行间距)

在 HTML 中,一个段落中的文字会从左到右依次排列,直到浏览器窗口的右端,然后才自动换行。

如果希望某段文本强制换行显示,就需要使用换行标签 <br>

<br>

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

**标签语义:**强制换行。

特点:

  • <br> 是个单标签
  • <br> 标签只是简单地开始新的一行,跟段落不一样,所以不会产生段间距

分割线标签:<hr>

<hr>
<!-- 某些时候需要对内容块进行分割时会用到分割线标签 -->

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

2.7列表

表格是用来显示数据的,那么列表就是用来布局的

列表最大的特点就是:整齐、整洁、有序、它作为布局会更加自由和方便。

在实际开发中凡是遇到排列整齐的简洁内容,都可以使用列表来进行布局。

合理的使用列表布局可以有效提高 SEO。

根据使用情景不同,列表可以分为三大类:无序列表有序列表自定义列表

标签名定义说明
<ul> </ul>无序标签里面只包含 li,没有顺序,使用较多,li 里面可以包含任何标签
<ol> </ol>有序标签里面只包含 li,有顺序,使用相对较少,li 里面可以包含任何标签
<dl> </dl>自定义标签里面只能包含 dt 和 dd,dt 和 dd 里面可以放任何标签,dd 一般作为对 dt 的细分描述

2.7.1 无序列表

<ul> 标签表示 HTML 页面中项目的无序列表,一般会以项目符号呈现列表项,而列表项使用 <li> 标签定义(开发中经常使用)。

无序列表的基本语法格式如下:

<ul>
    <li>列表项1</li>
    <li>列表项2</li>
    <li>列表项3</li>
    ...
</ul>
  • 无序列表的各个列表项之间没有顺序级别之分,是并列的
  • <ul> </ul> 中只能嵌套 <li> </li>,直接在 <ul> </ul> 标签中输入其他标签或者文字的做法是不被允许的,列表中的任何内容都应该放在 li
  • <li></li> 之间相当于一个容器,可以容纳所有的元素
  • 无序列表会带有自己的样式属性(比如圆点),但在实际开发中,我们会使用 CSS 来设置

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

2.7.2 有序列表

有序列表即为有序排列顺序的列表,其各个列表项会按照一定的顺序排列定义(开发中不太常用)。

在 HTML 标签中,<ol> 标签用于定义有序列表,列表排序以数字来显示,并且使用 <li> 标签来定义列表项。

有序列表的基本语法格式如下:

<ol>
    <li>列表项1</li>
    <li>列表项2</li>
    <li>列表项3</li>
    ...
</ol>
  • <ol> </ol> 中只能嵌套 <li> </li>,直接在 <ol> </ol> 标签中输入其他标签或者文字的做法是不被允许的
  • <li></li> 之间相当于一个容器,可以容纳所有的元素
  • 有序列表会带有自己样式属性(比如序号),但在实际使用时,我们会使用 CSS 来设置

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

2.7.3 自定义列表

自定义列表的使用场景:

自定义列表常用于对术语或名词进行解释、描述和展开,定义列表的列表项前没有任何项目符号(开发中常用)。

在 HTML 标签中,<dl> 标签用于定义描述列表(或定义列表),该标签会与 <dt>(定义项目/名字)和 <dd>(描述每一个项目/名字)一起使用。

其基本语法如下:

<dl>
    <dt>名词1</dt>
    <dd>名词1解释1</dd>
    <dd>名词1解释2</dd>
</dl>
  • <dl> </dl> 里面只包含 <dt><dd>
  • <dt><dd> 个数没有限制,经常是一个 <dt> 对应多个 <dd>

2.8超链接

在 HTML 标签中,<a> 标签用于定义超链接,作用是从一个页面链接到另一个页面。

(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 属性中,设置属性值的 #名字 的形式,如:<a href="#two">第2集</a>
    • 找到目标位置标签(此处以 h3 标签为例),里面添加一个 id属性="刚才的名字",如:<h3 id="two">第2集介绍</h3>
    • <a href="#"></a> 默认定位到页面顶部
    <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>
    

2.9路径

2.9.1相对路径

相对路径:以引用文件所在位置为参考基础,而建立出目录路径。

image-20220701140953053)

<!--           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>

2.9.2绝对路径

绝对路径:指目录下的绝对位置,直接到达目的位置,通常是从盘符开始的路径。

如 Windows 系统的绝对路径:D:\web\img\logo.png

2.9.3网络地址

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

2.10图片

2.10.1基本使用

在 HTML 标签中,<img> 标签用于定义 HTML 页面中的图像。

<img src="图像URL">

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

src<img> 标签的必须属性,它用于指定图像文件的路径和文件名。

URL统一资源定位符(通俗理解:地址、网址)。

所谓属性:简单理解就是属于这个图像标签的特性。

图像标签的其他属性:

属性属性值说明
src图片路径必须属性
alt文本替换文本,图像显示失败时显示(为了提高 SEO 及适配屏幕阅读器,建议都把 alt 写上)
title文本提示文本,鼠标放到图片上,显示的提示文字
width像素设置图像的宽度(了解,后面通过 CSS 设置)
height像素设置图像的高度(了解,后面通过 CSS 设置)
border像素设置图像的边框粗细(了解,后面通过 CSS 设置)

图像标签的注意点:

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

2.10.2图片格式

jpeg(jpg)
  • 支持的颜色比较丰富

  • 不支持透明效果

  • 不支持动图

  • 一般用来显示照片

gif
  • 支持的颜色比较单一

  • 支持简单透明

  • 支持动图

png
  • 支持的颜色丰富

  • 支持复杂透明

  • 不支持动图

  • 专为网页而生

webp
  • 这种格式是谷歌新推出的专门用来表示网页中的图片的一种格式

  • 具备其他图片格式的所有优点,而且文件还特别的小

  • 缺点:兼容性不好

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

  • 图片效果不一样的,选图片效果好的

  • 尽可能的兼顾和平衡图片效果和文件大小

2.11内联框架

内联框架iframe,用于向当前页面中引入一个其他页面,

  • src指定要引入的网页的路径

  • frameborder指定内联框架的边框

举例

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

image-20220701141545552

设置高度与宽度

heightwidth 属性用来定义 iframe 标签的高度与宽度。

属性默认以像素为单位,但是你可以指定其按比例显示(如:“70%”)。

<iframe height="500px" src="https://www.bilibili.com/" width="70%"></iframe>

image-20220701141653205

**提示:**您可以把需要的文本放置在 <iframe></iframe> 之间,这样就可以应对不支持 <iframe> 的浏览器。

**提示:**使用 CSS 为 <iframe>(包括滚动条)定义样式。

使用 CSS 隐藏 <iframe> 滚动条

  • 遮掉 iframe 滚动条:
<div style="width: 400px; overflow: hidden">
    <iframe height="480" src="https://www.runoob.com" width="415">您的浏览器不支持</iframe>
</div>
  • 新选择器原生移除滚动条:
<!-- 此方法目前暂不推荐使用 -->
<head>
  <style>
    iframe::-webkit-scrollbar { 
      display: none;
    }
  </style>
</head>

通过iframe的方式引入视频。以某艺为例,提供了视频链接的HTML代码和通用代码

image-20220701142416714

<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>

2.12音视频

2.12.1音频

HTML5 在不使用插件的情况下,也可以原生的支持音频格式文件的播放。当然,支持的格式是有限的。

当前 <audio> 元素支持三种音频格式:尽量使用 mp3 格式。

image-20220731131821813

audio标签用来向页面中引入一个外部的音频文件

音视频文件引入时,默认情况下不允许用户自己控制播放停止

属性

  • controls是否允许用户控制播放

  • autoplay音频文件是否自动播放

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

语法

<audio src="文件地址" controls="controls"></audio>
<audio src="./source/audio.mp3" controls autoplay loop></audio>

image-20220701142208439

常见属性:

image-20220731131939369

2.12.2source

除了通过src属性来指定外部文件的路径以外,还可以通过<source>元素来指定文件的路径

<audio controls="controls">
	<source src="happy.mp3" type="audio/mpeg">
	<source src="happy.ogg" type="audio/ogg">
	您的浏览器暂不支持 <audio> 标签。
</audio>

2.12.3视频

HTML5 在不使用插件的情况下,也可以原生的支持视频格式文件的播放。当然,支持的格式是有限的。

当前 <video> 元素支持三种视频格式:尽量使用 mp4 格式。

image-20220731131303045

使用video标签来向网页中引入一个视频,使用方式和audio基本上是一样的

语法:

<video src="文件地址" controls="controls"></video>
<video controls="controls" width="300"> 
    <source src="move.ogg" type="video/ogg"> 
    <source src="move.mp4" type="video/mp4"> 
    您的浏览器暂不支持 <video> 标签播放视频
</ video >

image-20220701142333645

常见属性:

<!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>

image-20220731131444522

2.13.4多媒体标签总结

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

DSelegent

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值