字符实体与语义标签

1. 字符实体

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

  • 多个连续的空格(在网页中编写的多个空格默认情况会自动被浏览器解析为一个空格)
  • 比如字母两侧的大于小于号(可能会被认为是标签并解析)

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

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

2. meta标签

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

【Web前端HTML5&CSS3】03-字符实体与语义标签-LMLPHP

<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主要用于设置网页中的一些元数据,元数据并不是给用户看的

  • :指定网页的字符集

  • :指定的数据的名称

    • :表示网站的关键字,可以同时指定多个关键字,关键字间使用,隔开

    • :表示网站的描述信息

      【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

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

打开Zeal手册(前端开发准备中做过介绍)

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

发现除了charsetnamecontent之外,还有一个叫的属性

If the http-equiv attribute is set, the <meta> element is a pragma directive, providing information equivalent to what can be given by a similarly-named HTTP header.

如果设置了http-equiv属性,<meta>元素就是一个pragma指令,提供的信息相当于一个类似名称的HTTP头所能提供的信息。

点击http-equiv的链接,查看其更详细信息。

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

  • content-security-policy:允许页面作者为当前页面定义一个。内容策略主要指定允许的服务器来源和脚本端点,这有助于防范跨站脚本攻击。
  • content-type:声明文档的。如果指定,content属性必须有 "text/html; charset=utf-8 "的值。这相当于一个指定了charset属性的<meta>元素,并对文档中的位置有同样的限制。注意:只能在使用text/html的文档中使用,不能在使用XML MIME类型的文档中使用。
  • default-style:设置默认的CSS样式表集的名称。
  • x-ua-compatible: 如果指定,内容属性必须有 "IE=edge "的值。用户代理被要求忽略这个pragma。
  • :该指令指定页面重新加载及重定向的方式
    • 直到页面应该被重新加载的秒数--只有当content属性包含一个正整数时。
    • 直到页面重定向到另一个页面的秒数--只有当内容属性包含一个正整数,后面跟着字符串';url=',以及一个有效的URL。

其中我们直接将Examples中的示例代码加入Demo.html中

<meta charset="utf-8">
<!-- Redirect page after 3 seconds -->
<meta http-equiv="refresh" content="3;url=https://www.mozilla.org">

refresh进行测试,发现过了3秒钟之后自动跳转到了指定的网站

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

3. 语义标签

在网页中HTML专门用来负责网页的结构所以在使用html标签时,应该关注的是标签的语义,而不是它的样式

这里先介绍几个基本的语义标签,还有些常用的标签放在后面具体讲解

举例

<h1>Beetles</h1>
<h2>External morphology</h2>
<h3>Head</h3>
<h4>Mouthparts</h4>
<h3>Thorax</h3>
<h4>Prothorax</h4>
<h4>Pterothorax</h4>

效果

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

HTML5 提供的新语义元素有

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

4. 块元素与行内元素

块元素(block element)

  • 在网页中一般通过块元素来对页面进行布局

行内元素(inline element)

  • 行内元素主要用来包裹文字
  • 一般情况下会在块元素中放行内元素,而不会在行内元素中放块元素
    • <p>元素中不能放任何的块元素,不过

5. 内容修正

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

  • 标签写在了根元素的外部
  • <p>元素中嵌套了块元素
  • 根元素中出现了除headbody以外的子元素

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

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

6. 布局标签

结构化语义标签

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

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

  • div 块元素,没有任何的语义,就用来表示一个区块。目前来讲,div还是主要的布局元素
  • span 行内元素,没有任何的语义,一般用于在网页中选中文字

7. 列表

在html中可以创建列表,html列表一共有三种:

  • 有序列表,使用ol标签来创建无序列表,使用li表示列表项

    <ol>
        <li>Mix flour, baking powder, sugar, and salt.</li>
        <li>In another bowl, mix eggs, milk, and oil.</li>
        <li>Stir both mixtures together.</li>
        <li>Fill muffin tray 3/4 full.</li>
        <li>Bake for 20 minutes.</li>
    </ol>
    

    【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

  • 无序列表,使用ul标签来创建无序列表,使用li表示列表项

    <ul>
        <li>Milk</li>
        <li>Cheese
            <ul>
                <li>Blue cheese
                    <ul>
                        <li>Sweet blue cheese</li>
                        <li>Sour blue cheese</li>
                    </ul>
                </li>
                <li>Feta</li>
            </ul>
        </li>
    </ul>
    

    【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

    可以看出,列表元素之间是可以互相嵌套的

  • 定义列表,使用dl标签来创建定义列表,使用dt表示定义的内容,使用dd来对内容进行解释说明

    <dl>
        <dt>Beast of Bodmin</dt>
        <dd>A large feline inhabiting Bodmin Moor.</dd>
    
        <dt>Morgawr</dt>
        <dd>A sea serpent.</dd>
    
        <dt>Owlman</dt>
        <dd>A giant owl-like creature.</dd>
    </dl>
    

    【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

8. 超链接

超链接可以让我们从一个页面跳转到其他页面,或者是当前页面的其他的位置

使用a标签来定义超链接,href属性指定跳转的目标路径,值可以是一个外部网站的地址,也可以写一个内部页面的地址

超链接是也是一个行内元素,在a标签中可以嵌套除它自身外的任何元素

外部地址

  • Linking to an absolute URL:链接一个绝对路径
  • Linking to an email address:链接一个email地址
  • Linking to telephone numbers:链接电话号码
  • Using the download attribute to save a <canvas> as a PNG:下载图片
<ul>
  <li><a href="https://www.baidu.com">Website</a></li>
  <li><a href="mailto:[email protected]">Email</a></li>
  <li><a href="tel:+123456789">Phone</a></li>
</ul>

效果

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

内部地址

当我们需要跳转一个服务器内部的页面时,一般我们都会使用相对路径,会以./../开头

  • ./ 表示当前文件所在目录,可以省略不写
  • ../表示当前文件所在目录的上一级目录
<a href="./test1.html">超链接1</a><br><a href="../test2.html">超链接2</a><br><a href="./test3/test3.html">超链接3</a><br><a href="../test4/test4.html">超链接4</a>

效果

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

新建页面

target属性,用来指定超链接打开的位置可选值:

  • _self在当前页面中打开超链接,默认值
  • _blank在新建页面中打开超链接
<a href="./test1.html">超链接1——默认</a><br><a href="./test1.html" target="_self">超链接1——当前页面</a><br><a href="./test1.html" target="_blank">超链接1——新建页面</a><br>

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

锚点跳转

可以使用javascript:void(0);来作为href的属性,此时点击这个超链接什么也不会发生

可以将#作为超链接的路径的占位符使用。

可以直接将超链接的href属性设置为#,这样点击超链接以后页面不会发生跳转,而是转到当前页面的顶部的位置

可以跳转到页面的指定位置(锚点),只需将href属性设置#目标元素的id属性值(唯一不重复)

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

效果

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

9. 图片

图片标签用于向当前页面中引入一个外部图片

img标签是一个自结束标签,这种元素属于替换元素(块和行内元素之间,具有两种元素的特点)

属性

  • src:属性指定的是外部图片的路径(路径规则和超链接是一样的)
  • alt:图片的描述,这个描述默认情况下不会显示,有些浏览器会在图片无法加载时显示,搜索引擎会根据alt中的内容来识别图片
  • width:图片的宽度(单位是像素)
  • height :图片的高度(单位是像素)
  • 宽度和高度中如果只修改了一个,则另一个会等比例缩放

注意

  • 一般情况在pc端,不建议修改图片的大小,需要多大的图片就裁多大
  • 但是在移动端,经常需要对图片进行缩放(大图缩小)

举例

<img src="https://gitee.com/vectorx/ImageCloud/raw/master/img/20210513002416.png" alt="蒂姆·伯纳斯·李爵士,万维网的发明人"><img src="https://gitee.com/vectorx/ImageCloud/raw/master/html5/20210514233853.gif" alt="结构、表现、行为">

效果

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

图片格式

jpeg(jpg)

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

gif

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

png

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

webp

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

base64

  • 将图片使用base64编码,这样可以将图片转换为字符,通过字符的形式来引入图片

    <img width="300" src="" />
    

    图片格式的选择

  • 图片效果一样的,选文件小的

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

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

10. 内联格式

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

  • src指定要引入的网页的路径
  • frameborder指定内联框架的边框

举例

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

效果

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

11. 音视频

音频

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

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

属性

  • controls是否允许用户控制播放
  • autoplay音频文件是否自动播放
    • 如果设置了autoplay,则音乐在打开页面时会自动播放
    • 但是目前来讲大部分浏览器都不会自动对音乐进行播放
  • loop音乐是否循环播放
<audio src="./source/audio.mp3" controls autoplay loop></audio>

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

source

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

<audio controls autoplay loop>    对不起,您的浏览器不支持播放音频!请升级浏览器!	<source src="./source/audio.mp3">	<source src="./source/audio.ogg"></audio>

IE11下,能够正常播放

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

IE8下,出现我们自定义的提示信息

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

embed

IE8下不支持audio元素,但是可以使用 <embed> 元素在文档中的指定位置嵌入外部内容。

这个内容是由外部应用程序或其他互动内容的来源提供的,如浏览器插件。

<embed src="./source/audio.mp3">

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

视频

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

<video controls>    <source src="https://interactive-examples.mdn.mozilla.net/media/cc0-videos/flower.webm" type="video/webm">    <source src="https://interactive-examples.mdn.mozilla.net/media/cc0-videos/flower.mp4" type="video/mp4">    <embed src="https://interactive-examples.mdn.mozilla.net/media/cc0-videos/flower.mp4" type="video/mp4"></video>

IE11下,能够正常播放

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

IE8下,也能正常播放

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

其他

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

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

【Web前端HTML5&amp;CSS3】03-字符实体与语义标签-LMLPHP

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

不过,embed需要flash的支持

<embed       src="//player.video.iqiyi.com/0c53ddd55f262c6d416afa9d1f49dc55/0/0/v_19rrcuh1jw.swf-albumId=1008748400-tvId=1008748400-isPurchase=0-cnId=undefined"       allowFullScreen="true" quality="high" width="480" height="350" align="middle" allowScriptAccess="always"       type="application/x-shockwave-flash"></embed>
05-16 19:15