2021-07-14

笔记来源:尚硅谷Web前端HTML5&CSS3初学者零基础入门全套完整版

字符实体与语义标签

1. 字符实体

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

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

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

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

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

2. meta标签

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

image-20210514225741114

<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,相机,数码,配件,手表,存储卡,京东"/>

   
   
  • 1
  • 2
  • 3
  • 4

meta主要用于设置网页中的一些元数据,元数据并不是给用户看的

  • charset :指定网页的字符集

  • name :指定的数据的名称

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

    • description:表示网站的描述信息

      image-20210514230338273

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

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

image-20210514230900103

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

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.

   
   
  • 1

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

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

image-20210514231126506

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

   
   
  • 1
  • 2
  • 3

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

sxx2l-rwqq5

3. 语义标签

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

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

标签作用描述
块元素
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>不属于语义标签

举例

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

   
   
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

效果

image-20210515212349676

HTML5 提供的新语义元素有

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

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

4. 块元素与行内元素

块元素(block element)

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

行内元素(inline element)

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

5. 内容修正

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

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

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

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

6. 布局标签

结构化语义标签

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

HTML5 语义元素

  • 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>
    
         
         
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7

    image-20210515212835770

  • 无序列表,使用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>
    
         
         
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14

    image-20210515213301387

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

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

    <dl>
        <dt>Beast of Bodmin</dt>
        <dd>A large feline inhabiting Bodmin Moor.</dd>
    
    <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>dt</span><span class="token punctuation">&gt;</span></span>Morgawr<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>dt</span><span class="token punctuation">&gt;</span></span>
    <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>dd</span><span class="token punctuation">&gt;</span></span>A sea serpent.<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>dd</span><span class="token punctuation">&gt;</span></span>
    
    <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>dt</span><span class="token punctuation">&gt;</span></span>Owlman<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>dt</span><span class="token punctuation">&gt;</span></span>
    <span class="token tag"><span class="token tag"><span class="token punctuation">&lt;</span>dd</span><span class="token punctuation">&gt;</span></span>A giant owl-like creature.<span class="token tag"><span class="token tag"><span class="token punctuation">&lt;/</span>dd</span><span class="token punctuation">&gt;</span></span>
    

</dl>

  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

image-20210515212936773

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:example@outlook.com">Email</a></li>
  <li><a href="tel:+123456789">Phone</a></li>
</ul>

 
 
  • 1
  • 2
  • 3
  • 4
  • 5

效果

动画2021-5-15

内部地址

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

  • ./ 表示当前文件所在目录,可以省略不写
  • ../表示当前文件所在目录的上一级目录
<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>

 
 
  • 1
  • 2
  • 3
  • 4

效果

动画2021-5-11

新建页面

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>

 
 
  • 1
  • 2
  • 3

动画2021-5-10

锚点跳转

可以使用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>

  • 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

效果

动画2021-5-14

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="结构、表现、行为">

 
 
  • 1
  • 2

效果

image-20210515233449533

图片格式

jpeg(jpg)
  • 支持的颜色比较丰富
  • 不支持透明效果
  • 不支持动图
  • 一般用来显示照片
gif
  • 支持的颜色比较单一
  • 支持简单透明
  • 支持动图
png
  • 支持的颜色丰富
  • 支持复杂透明
  • 不支持动图
  • 专为网页而生
webp
  • 这种格式是谷歌新推出的专门用来表示网页中的图片的一种格式
  • 具备其他图片格式的所有优点,而且文件还特别的小
  • 缺点:兼容性不好
base64
  • 将图片使用base64编码,这样可以将图片转换为字符,通过字符的形式来引入图片

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

    图片格式的选择

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

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

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

10. 内联格式

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

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

举例

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

 
 
  • 1

效果

image-20210516001417802

11. 音视频

音频

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

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

属性

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

 
 
  • 1

image-20210516002915651

source

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

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

 
 
  • 1
  • 2
  • 3
  • 4
  • 5

IE11下,能够正常播放

image-20210516004453236

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

image-20210516005054543

embed

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

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

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

 
 
  • 1

image-20210516005207428

视频

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

 
 
  • 1
  • 2
  • 3
  • 4
  • 5

IE11下,能够正常播放

image-20210516012905334

IE8下,也能正常播放

image-20210516010618514

其他

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

image-20210516011905816

image-20210516011837229

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

 
 
  • 1
  • 2
  • 3

不过,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>

 
 
  • 1
  • 2
  • 3
  • 4
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值