首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >HTML语法规范

HTML语法规范

作者头像
h3110_w0r1d
发布于 2024-02-19 11:07:55
发布于 2024-02-19 11:07:55
29500
代码可运行
举报
运行总次数:0
代码可运行

XHTML的出现是为了过渡到xml

HTML中不区分大小写,但是我们一般都使用小写

HTML的注释不能嵌套(就和c++中的if-else一样)

HTML标签必须结构完整,要么成对出现,要么自结束标签

  1. 浏览器会尽最大努力正确解析页面,不符合语法规范的内容,浏览器会自动修正
  2. 但是有些情况会修正错误 F12会跳出开发者控制台 自结束标签:
  3. html5中< br >
  4. xhtml中< br />(最后有反斜杠) HTML标签可以嵌套,但是不能交叉嵌套 HTML标签中的属性必须有值,且值必须加引号
  5. < font color=”red” >
  6. 单双引号均可

live-server快捷键

  1. 写标签的名字后按tab键补全
  2. 写开始标签,回车自动补全
  3. ctrl+/,自动生成注释标签

元素

定义:

  1. HTML中元素指的是从开始标签到结束标签的所有代码,或者开放标签和闭合标签

实体

在网页中,编写的多个空格,会被浏览器自动解析为一个空格

在html中我们不能直接书写一些特殊符号,比如连续多个空格,比如字母两侧的大于和小于号

如果我们需要在网页中书写这些符号,需要使用html中的实体(转义字符)

实体的语法

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
&实体的名字;
    &nbsp;空格
    >大于号
    <小于号
    &copy;版权符号
&开头;结尾

meta标签

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
定义:the html <meta> represents metadata that cannot be represented by other html meta related elements,like <base>,<link>,<script>,<style>,<title>

可以提供页面元信息

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
元信息是指描述自身的信息,元信息类标签是指html中用于描述文档自身的一类标签
通常出现在head标签中,提供给浏览器或者搜索引擎阅读的,一般不会显示给用户

meta标签永远位于head元素内部

属性:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
content指定的数据内容
    charset: 指定网页的字符集
    name: 指定数据的名称
    content: 指定数据的内容
    keywords: 表示网站的关键字
    description: 用于指定网站的描述,显示在搜索引擎中的搜索结果中

title标签的内容会作为搜索结果的超链接上的文字显示

必须

  1. content:定义与http-equiv或name属性相关的元信息(使用,进行分割)可选:
  2. http-equiv:把content属性关联到HTTP头部
  3. name:把content属性关联到一个名称– name和content是一对关键字
  4. scheme:定义用于翻译content属性值的格式
  5. description:
name
  1. keywords:为文档定义了一组关键字,某些搜索引擎在遇到这些关键字时会用这些关键字对文档进行分类。< meta name=”keywords” content=”HTML,ASP,PHP” />(会将HTML等内容进行转keywords操作,content内容使用,进行分割)

http-equiv

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
用来设置http协议,将一个页面重定向到另一个网站,
  1. 为名称/值对提供了名称,并指示服务器在发送实际的文档之前先要传送给浏览器的MIME文档头部包含名称值对。
  2. 当服务器向浏览器发送文档时,会先发送许多名称/值对,但是所有的服务器都至少要发送一个。
  3. 使用带有http-equiv属性的meta标签时,服务器将把名称/值对添加到发送给浏览器的内容头部
  4. < meta http-equiv=”charset” content=”iso-8859-1”>
  1. 其中3表示时间,url表示往哪跳转,重定向到哪.之间用什么间隔

content

  1. 提供了名称/值对中的值,该值可以是任何有效的字符串
  2. content属性始终要和name属性或http-equiv属性一起使用重定向
  3. < meta http-equiv=”Refresh” content=”间隔时间;url=跳转页面的url”>

常用的标签:

二者之间的关系

  1. 一般情况下会在块元素中放行内元素
  2. 而不会在行内元素中放块元素
  3. 块元素中一般什么都能放
  4. 但是尤其注意:p元素中不能放任何的块元素

在页面中独占一行的元素称为块元素block element

  1. 在页面中一般通过块元素来对页面进行宏观布局

标题标签

  1. HTML中一共有六级标签:h1~h6
  2. h1最大,为一级;h6为最小,为6级
  3. 一般不用,主要是css来修改
  4. 使用HTML标签时,关心的是标签的语义,我们使用的标签都是语义化标签
  5. 6级标签中,h1最重要,表示一个网页中的主要内容,h2~h6的重要性一次降低
  6. 搜索引擎先搜素title标签,然后就会搜索标题标签,从h1到h6
对于搜索引擎来说,h1的重要性仅次于title,搜索引擎检索完title,会立即查看h1中的内容
  1. h1标签非常重要,会影响页面再搜索引擎中的排名,页面只能写一个h1
  2. 一般页面标题中只使用h1,h2,h3,h3以后的基本不使用
< hgroup>
  1. hgroup用来为标题分组,可以将一组相关的标题同时放入到hgroup
  2. 分组的目的是用css单独控制这个组,方便修改样式
代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<hgroup>
    <h1>...</h1>
    <h2>...</h2>
</hgroup>
< header>标签
  1. < header></ header>
  1. 定义网页的头部
  2. 可以是网页的某一个部分的头部,所以header标签可以不只有一个
< main>
  1. 网页的主体部分
  2. 和c++main函数一样,一个页面中只能有一个
< footer>
  1. 网页的底部
  1. 可以是网页的某一个部分的底部,所以footer标签不只有一个
< nav>

表示网页的导航

< nav>标签里面放< a>(超链接)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<nav>
<a href="https://www.baidu.com">baidu</a>
<nav>
< aside>
  1. 和主体相关又不属于主体
  2. 对文章中的某一个字或词在旁边进行图解注释
< article>
  1. 表示一个独立的文章
  2. 每一个独立的< article>都可以插入小的< article>
< section>
  1. 表示一个独立的区块(其它)
  2. 上面的标签都不能表示时,使用section
  3. 例如header里面放三个section
< div>
  1. 没有语义,就是用来表示一个区块
  2. 上面的< hgroup>,< header>,< aside>,< article>,< section>,< nav>都可以用div来代替

段落标签

  1. 用于表示内容中的一个自然段,使用p标签来表示一个段落
  2. < p>中间放段落< /p>
  3. p标签中的文字,默认会独占一行,并且段和段之间会有一个间
  4. 但是如果没有p标签则会出现在一行,并且行与行之间没有间距

< br>

  1. 在页面中也可以使用br标签来表示一个换行,br标签是一个自结束标签

< hr>

  1. < hr />,hr标签也是一个自结束标签,可以在页面中生成一条水平线

在页面中不会独占一行的元素称为行内元素(inline element)

  1. 和布局无关
  2. 主要用来包裹文字

< em>加重语气标签

  1. 样式会和其它的没有em的字体不同,可能会斜体,突出
  2. 没有换行
  3. 只是语气的加重

< strong>

  1. 表示强调,重要内容
  2. 是整体的强调作用

< q>

  1. 表示引用
  2. 短引用
  3. 会有引号,但是不会缩进

< blockquote>

  1. 块引用(长引用)
  2. 会缩进,没有引号

< span>

  1. 行内元素,没有任何的语义,一般用于在网页中选中文字

浏览器的自动修正

  1. 浏览器在解析网页时,会对网页中不符合规范的内容进行修正
  2. 比如标签写在了根< html>的外部
  3. p元素中嵌套了块元素
  4. 根元素中出现了head和body以外的子元素注意
  5. 修正的不是源码
  6. 而是源码在内存中的形式
  7. 看的是f12打开后的element元素

实体

在HTML中< >这种特殊字符不能直接使用(<>会被解析为标签)

  1. 需要使用一些特殊的符号来表示这些特殊字符,这些特殊符号我们称为实体(转义字符串)
  2. 浏览器解析到实体时,会自动将实体转换为其对应的字符

在HTML中,字符之间写再多的空格,浏览器也会当成一个空格解析,换行也会当成一个空格解析

语法

  1. &实体的名字(将linux系统操作的-换位&)(只能说是一部分)
  2. 小于< -lt
  3. 大于> -gt
  4. 空格 (牛逼space)(no break space,即不会换行的空格)
  5. 版权符号 &copy(不让你copy)&开头,;结尾

图片标签

使用img(image)标签来向网页中引入一个外部图片

  1. img标签也是一个自结束标签属性
  2. img标签属于一种替换元素,介于行内元素和块元素之间,具备行内元素和块元素的特点src:设置一个外部图片的路径
  3. 路径规则和超链接是一样的,src指定的是外部图片的路径alt:可以用来设置图片的描述
  4. (当图片不能显示时,直接显示alt中的内容),搜索引擎可以通过alt属性来识别不同的图片(百度专门搜索图片的时候就是用alt)
  5. 如果不写alt,搜索引擎将不会对img中的图片进行收录width:可以用来修改图片的宽度,一般使用px为单位(像素) height:可以用来修改土拍你的高度,一般使用px为单位,宽度和高度如果只设置一个,另一个也会同时等比例调整大小 如果两个值同时指定,则按照你指定的值来设置
  6. 如果两个值同时指定,则按照你指定的值来设置一般开发中除了自适应页面,不建议设置width和height
  7. 让美工话自己想要的大小< img src=”路径” alt=”图片描述” /> 图片格式
  8. JPEG(JPG):支持的颜色比较多,图片可以压缩,但是不支持透明(指的是背景透明),一般用来保存照片等颜色丰富的图片
  9. GIF:支持的颜色少,只支持简单的透明(背景透明)(但是边界会有白边),支持动态图,图片颜色单一或者是动态图时可以使用gif
  10. PNG:支持的颜色多,并且支持复杂的透明(背景透明),可以用来显示颜色复杂的透明的图片图片的使用原则:
  11. 效果不一致用好的
  12. 效果一致用小的(jpg一般小于png)

列表(list)

成组出现

无序列表

  1. 使用ul标签来创建无序标签
  2. 使用li表示列表项

有序列表

  1. 使用ol标签来创建有序标签

定义列表

  1. 为一些东西下定义
  2. 使用< dl>标签来创建定义列表
  3. 使用< dd>标签来对内容进行解释说明
  4. 使用下拉菜单时可以使用

列表之间可以互相嵌套

超链接

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

< a>

  1. 使用a标签来创建超链接
  2. 是一个行内元素
  3. < a>标签中可以放任何元素

属性href

  1. href指定跳转的目标路径
  1. 值可以是一个外部页面的地址
  2. 也可以写一个内部页面的地址
  3. 当在同一个目录下,可以写相对于当前目录的地址

可以写绝对路径

也可以写相对路径

  1. 当我们需要跳转到服务器内部的页面时,一般用相对路径
  2. ./可以省略不写,如果不写./,也不写../,则相当于写了./
  3. ./07.html和07.html相同

通过颜色的区别来区分

  1. 紫色的是点过的
  2. 蓝色的是没有点过的

超链接的其它用法

跳转出一个新的页面,而不是覆盖掉当前页面

target属性
  1. _self默认值,在当前页面中打开超链接
  2. _blank,在一个新的页面中打开超链接
  3. 国内用_blank很多,但是会在不经意间打开很多窗口,所以国外使用_self较多

回到顶部

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<a href="#",target="">

回到底部

  1. 没有特殊的回到底部的href属性
  2. 可以通过设置id属性,使其跳转到”回到顶部”标签所在的位置
  3. 当id重复时,前面的id具有优先性,起那面的会生效

id属性

唯一不重复的

每一个标签都可以添加一个id属性

id属性就是元素的唯一标识,同一个页面中不能出现重复的id属性

一般id的格式都是先一个小写英文字母,后数字

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<a href="#p3"></a>

跳转到指定位置

  1. 只需要将href属性设置为:#目标元素的id属性值

#作为占位符

  1. 在开发中可以将#作为超链接的占位符使用

生成随机文本

lorem

  1. 格式:lorem + 单词数量
  2. 乱数假文,用于排版领域来测试不同文本下的显示状态

内联框架

  1. 用于向当前页面中引入一个其它页面< iframe>,参数
  2. src=””,被引入的页面
  3. width=””
  4. height=””
  5. frameborder:””内联框架的边框,0表示没有,1表示有

注意

  1. 内联框架中的东西不会被搜索引擎所检索,即内联框架是一个标签而已

音频播放

< audio>

向一个页面中引入一个外部的音频文件

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

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<audio src=""></audio>

添加属性controls是否允许用户控制播放,想则写,不想则不写(通过是否来判断)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<audio src="" controls></audio>

autoplay 音频文件是否自动播放,但是大部分浏览器都不会自动对音乐进行播放(但是为了防止轰一下吓人一跳,提升用户体验,则不会自动播放)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<audio src="" controls autoplay></audio>

loop 循环播放

更标准的格式

除了可以通过src来指定外部文件的路径以外,还可以通过source来指定文件路径

支持< audio>标签的可以,不支持的忽略标签,但是中间的文字就可以暴露出来了

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<audio controls>
    对不起,您的浏览器不支持播放音频,请升级浏览器
    <source src="路径.mp3">
    <source src="路径.ogg">
</audio>

mp3和ogg都要写,因为有的浏览器不支持mp3,如果不支持第一个,可以播放第二个,有效地解决浏览器兼容性问题

视频播放

video标签来引入视频文件

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
<video controls>
    <source src="">
    <source src="">
</video>

IE浏览器模拟IE11或更低等级的方法

  1. f12打开开发者工具
  2. 选择文档模拟器
  1. 即可模拟IE11及以下的内核
本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-01-15,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
一、HTML
html概述和基本结构 html概述 HTML是 HyperText Mark-up Language 的首字母简写,意思是超文本标记语言,超文本指的是超链接,标记指的是标签,是一种用来制作网页的语言,这种语言由一个个的标签组成,用这种语言制作的文件保存的是一个文本文件,文件的扩展名为html或者htm,一个html文件就是一个网页,html文件用编辑器打开显示的是文本,可以用文本的方式编辑它,如果用浏览器打开,浏览器会按照标签描述内容将文件渲染成网页,显示的网页可以从一个网页链接跳转到另外一个网页。 ht
酱紫安
2018/04/16
4.7K0
一、HTML
知识整理之HTML篇
HTML5 不基于 SGML,因此不需要对DTD进行引用,但是需要doctype来规范浏览器的行为(让浏览器按照它们该有的方式来运行) 而HTML4.01基于SGML,所以需要对DTD进行引用,才能告知浏览器文档所使用的文档类型。
Clearlove
2019/08/29
1.4K0
HTML——学习笔记
HTML不是一种编程语言,它是一种超文本标记语言(Hyper Text Markup Language),标记语言是一套标记标签(Markup tag),浏览器通过HTML标记标签来构造描述我们访问的网页。
IMWeb前端团队
2019/12/03
1.1K0
HTML——学习笔记
HTML全标签语法总结——前端从入门到学废
HTML(超文本标记语言——HyperText Markup Language)是构成 Web 世界的一砖一瓦。它定义了网页内容的含义和结构。除 HTML 以外的其它技术则通常用来描述一个网页的表现与展示效果(如[CSS]),或功能与行为(如 [JavaScript])。
JanYork_简昀
2024/03/07
1.2K0
HTML全标签语法总结——前端从入门到学废
HTML
HTML是 HyperText Mark-up Language 的首字母简写,意思是超文本标记语言,超文本指的是超链接,标记指的是标签,是一种用来制作网页的语言,这种语言由一个个的标签组成,用这种语言制作的文件保存的是一个文本文件,文件的扩展名为html或者htm,一个html文件就是一个网页,html文件用编辑器打开显示的是文本,可以用文本的方式编辑它,如果用浏览器打开,浏览器会按照标签描述内容将文件渲染成网页,显示的网页可以从一个网页链接跳转到另外一个网页。
py3study
2020/01/16
1.7K0
前端(一)-Html
注意:块元素可以嵌套多个行内元素标签,但行内元素不能嵌套块元素,会改变行内元素的布局,且标签之间不可以交叉;
化羽羽
2022/10/28
4.9K0
html初识
本质:所有的Web应用,本质上其实就是一个socket服务端,用户的浏览器其实就是一个socket客户端。
全栈程序员站长
2022/07/21
9130
html初识
前端基础101之HTML总结
最近在用vue做个人主页,由于前端已经快三年没写过了,因此借着这个机会顺便复习一下前端知识。
timerring
2025/05/24
1880
HTML入门与进阶以及HTML5_html 菜鸟教程
HTML入门与进阶以及HTML5_html 菜鸟教程目录一、简介1、前端开发最核心技术(1)HTML是什么?(2)CSS(3)JavaScript2、前端开发其他技术二、基础内容1.基础总结2.HTML的基本标签(1)HTML标签(2)head标签(3)body标签3、段落与文字(一)、段落标签(二)、网页特殊符号(三)、自闭合标签(四)、块元素和行内元素(五)、练...
Java架构师必看
2022/05/10
4.5K0
HTML入门与进阶以及HTML5_html 菜鸟教程
HTML
一个完整的网页是由HTML(超文本标记语言),css(层叠样式表)JavaScript(动态脚本语言)三部分组成.
Wyc
2018/09/11
2.5K0
HTML
【Python3】HTML基础
BS(Browser-Server)模式:顾名思义为浏览器-服务器的意思,对比的话类似我们PC上面浏览器使用的产品即为BS模式产品,例如google doc、各类网站等。
py3study
2020/01/06
9690
01.前端之HTML
  浏览器发请求 --> HTTP协议 --> 服务端接收请求 --> 服务端返回响应 --> 服务端把HTML文件内容发给浏览器 --> 浏览器渲染页面
changxin7
2019/09/10
1.3K0
HTML
浏览器(browser application)是用来访问和浏览万维网页面的客户端软件,是显示、运行网页的平台。
用户9615083
2022/12/25
4.1K0
HTML
WEB前端入门 学习记录
更多html实体参考手册:HTML ISO-8859-1 参考手册 来源:W3SCHOOL
用户6948990
2025/04/03
1670
WEB前端入门 学习记录
html标签详解
<!DOCTYPE> 标签 <!DOCTYPE> 声明必须是 HTML 文档的第一行,位于 <html> 标签之前。 <!DOCTYPE> 声明不是 HTML 标签;它是指示 web 浏览器关于页面使用哪个 HTML 版本进行编写的指令。 <!DOCTYPE html> <head>内的标签 标签意义 <title></title> 定义网页标题 <style></style> 定义内部样式表 <script></script> 定义JS代码或引入外部JS文件 <link/> 引入外部
人生不如戏
2018/04/12
3K0
HTML
超文本标记语言(英语:HyperText Markup Language,简称:HTML)是一种用于创建网页的标准标记语言。 您可以使用 HTML 来建立自己的 WEB 站点,HTML 运行在浏览器上
用户1173509
2018/01/17
1.7K0
HTML
html基础
HTML 不是一种编程语言,而是一种标记语言 (markup language) HTML 使用标记标签来描述网页
超蛋lhy
2018/08/31
2.3K0
html基础
零基础学HTML5和CSS3前端开发第一课
HTML:超文本标记语言(Hyper Text Markup Language),标准通用标记语言下的一个应用。 HTML 不是一种编程语言(C、Java、python、R等),而是一种标记语言 (markup language),是网页制作所必备的。“超文本”就是指页面内可以包含图片、链接,甚至音乐、程序等非文字元素。 目前版本是第5代,简称为HTML5,该 技术结合了 HTML4.01 的相关标准并革新 。
张哥编程
2024/12/13
1650
零基础学HTML5和CSS3前端开发第一课
关于行、块元素的讲解以及HTML5元素的分类
继上周我们讲解了所有常用的CSS选择器以及CSS选择器的优先级。到目前为止,你是不是觉得静态页面布局简单了很多,而不是单单使用类名选择器(虽然很好用)来操作了。通过其它选择器的配合使用,页面布局显得不再那么让人“捉急”。但是有不少人在这个时候遇到了问题,多种多样的标签给我们的布局操作带来了一定的难度,因其种类繁多,大家在使用的时候出现了“选择困难症”。为此,今天的这篇文章主要为大家讲解网页中常用的标签以及它又是如何进行分类的。 本文内容概要: 1 行元素的使用 2 块元素的使用 2 行、块元素的特性区别 4
HTML5学堂
2018/03/13
3K0
关于行、块元素的讲解以及HTML5元素的分类
HTML以及CSS初级操作
html是用来描述网页的一种语言,是一种超文本标记语言。也就是说,html不是编程语言。也就是说,html不是一种编程语言,仅仅是一种标记语言。
Nagato_Yuki
2019/07/16
2.9K0
相关推荐
一、HTML
更多 >
LV.1
曲阜师范大学
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档