前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >前端入门系列之HTML

前端入门系列之HTML

作者头像
王大锤
发布2019-08-07 10:38:55
1.1K0
发布2019-08-07 10:38:55
举报
文章被收录于专栏:王大锤

前端入门系列之HTML

超文本标记语言 (英语:Hypertext Markup Language,简称:HTML ) 是一种用来结构化 Web 网页及其内容的标记语言。网页内容可以是:一组段落、一个重点信息列表、也可以含有图片和数据表。

HTML是什么


HTML 不是一门编程语言,而是一种用于定义内容结构的标记语言。HTML 由一系列的元素(elements)组成,这些元素可以用来包围不同部分的内容,使其以某种方式呈现或者工作。 一对标签 (tags)可以为一段文字或者一张图片添加超链接,将文字设置为斜体,改变字号,等等。 可以将这行文字封装成一个段落(paragraph)元素来使其在单独一行呈现:

代码语言:javascript
复制
<p>我的猫咪脾气爆 :)</p>

元素

元素组成

这个元素的主要部分有:

  1. 开始标签(Opening tag):包含元素的名称(本例为 p),被大于号、小于号所包围。表示元素从这里开始或者开始起作用 —— 在本例中即段落由此开始。
  2. 结束标签(Closing tag):与开始标签相似,只是其在元素名之前包含了一个斜杠。这表示着元素的结尾 —— 在本例中即段落在此结束。初学者常常会犯忘记包含结束标签的错误,这可能会产生一些奇怪的结果。
  3. 内容(Content):元素的内容,本例中就是所输入的文本本身。
  4. 元素(Element):开始标签、结束标签与内容相结合,便是一个完整的元素。

元素也可以有属性(Attribute)

HTML 属性

属性包含了关于元素的一些额外信息,这些信息本身不应显现在内容中。本例中,class 是属性名称,editor-note 是属性的值 。class 属性可为元素提供一个标识名称,以便进一步为元素指定样式或进行其他操作时使用。

属性应该包含:

  1. 在属性与元素名称(或上一个属性,如果有超过一个属性的话)之间的空格符。
  2. 属性的名称,并接上一个等号。
  3. 由引号所包围的属性值。

嵌套元素

也可以将一个元素置于其他元素之中 —— 称作嵌套。要表明猫咪非常暴躁,可以将 “爆” 用 <strong>元素包围,爆字将突出显示:

代码语言:javascript
复制
<p>我的猫咪脾气<strong>爆</strong>:)</p>

必须保证元素嵌套次序正确:本例首先使用 <p> 标签,然后是 <strong> 标签,因此要先结束 <strong> 标签,最后再结束 <p> 标签。这样是不对的:

代码语言:javascript
复制
<p>我的猫咪脾气<strong>爆:)</p></strong>

元素必须正确地开始和结束,才能清楚地显示出正确的嵌套层次。否则浏览器就得自己猜测,虽然它会竭尽全力,但很大程度不会给你期望的结果。所以一定要避免!

块级元素,内联元素和可变元素

1.块状元素(block element)

  1. 块状元素在网页中就是以块的形式显示,所谓块状就是元素显示为矩形区域,常用的块状元素包块div,dl,dt,dd,ol,ul,(h1-h6),p,form,hr,table,tr,td等;
  2. 默认情况下,块状元素都会占据一行,通俗地说,两个相邻块状元素不会出现并列显示的现象;默认情况下,块状元素会按顺序自上而下排列。
  3. 块状元素都可以定义自己的宽度和高度。
  4. 块状元素一般都作为其他元素的容器,它可以容纳其它内联元素和其它块状元素。

我们可以把这种容器比喻为一个盒子。

2.内联元素(inline element)(或是行内元素、行间元素、内嵌元素)

  1. 常见的内联元素如:a,span,i,em,strong,b,img,input等
  2. 内联元素的表现形式是始终以行内逐个进行显示;
  3. 内联元素没有自己的形状,不能定义它的宽和高,它显示的宽度、高度只能根据所包含内容的高度和宽度来确定,它的最小内容单元也会呈现矩形形状;
  4. 内联元素也会遵循盒模型基本规则,如可以定义padding,border,margin,background等属性,但个别属性不能正确显示;

3、可变元素

需要根据上下文关系确定该元素是块元素或者内联元素块元素(block element)

display: block/inline//list-item/table-cell/none;

大概有这么六种转变。盒模型主要下面三种转变。

Block: 块级元素,可以设置宽高,独占一行。

Inline: 内联元素,

inline-block:既能设置宽高 有能一行显示。

空元素

不包含任何内容的元素称为空元素。比如 <img> 元素:

代码语言:javascript
复制
<img src="images/firefox-icon.png" alt="测试图片">

本元素包含两个属性,但是并没有 </img> 结束标签,元素里也没有内容。这是因为图像元素不需要通过内容来产生效果,它的作用是向其所在的位置嵌入一个图像。

文档详解


随便打开一个网页源码,基本结构如下:

代码语言:javascript
复制
<!DOCTYPE html>
<html>
  <head>
    <meta charset="utf-8">
    <title>测试页面</title>
  </head>
  <body>
    <img src="images/firefox-icon.png" alt="测试图片">
  </body>
</html>
  • <!DOCTYPE html> — 文档类型。混沌初分,HTML 尚在襁褓(大约是 1991/92 年),DOCTYPE 用来链接一些 HTML 编写守则,有点像自动校正等。然而现在已经没有人关心这些,只是因为历史原因必须将它们保留,但没有实际作用。现在你只需要知道这些就可以。
  • <html></html> — <html> 元素。这个元素包含了整个页面的内容,有时也被称作根元素。
  • <head></head> — <head> 元素。这个元素放置的内容不是展现给用户的,而是包含例如面向搜索引擎的搜索关键字(keywords)、页面描述、CSS 样式表和字符编码声明等。
  • <meta charset="utf-8"> — 这个元素指定了当前文档使用 UTF-8 字符编码 ,UTF-8 包括绝大多数人类已知语言的字符。基本上 UTF-8 可以处理任何文本内容,还可以避免以后出现某些问题,我们没有任何理由再选用其他编码。
  • <title></title> — <title> 元素。这个元素设置页面的标题,显示在浏览器标签页上,同时作为收藏网页的描述文字。
  • <body></body> — <body> 元素。这个元素包含期望让用户在访问页面时看到的内容,可以是文本、图像、视频、游戏、可播放的音轨或其他内容。

HTML5 标签列表

以下为常用标签: | <html> | 代表 HTML 或 XHTML 文档的根。其他所有元素必须是这个元素的子节点。 | | <head> | 代表关于文档元数据的一个集合,包括脚本或样式表的链接或内容。 | | <title> | 定义文档的标题,将显示在浏览器的标题栏或标签页上。该元素只能包含文本,包含的标签不会被解释。 | | <link> | 用于链接外部的 CSS 到该文档。 | | <style> | 用于内联 CSS。 | | <script> | 定义一个内联脚本或链接到外部脚本。脚本语言是 JavaScript。 | | <body> | 代表 HTML 文档的内容。在文档中只能有一个 <body> 元素。 | | <p> | 定义一个段落。 | | <hr> | 代表章节、文章或其他长内容中段落之间的分隔符。 | | <ol> | 定义一个有序列表。 | | <ul> | 定义一个无序列表。 | | <li> | 定义列表中的一个列表项。 | | <a> | 代表一个链接到其他资源的_超链接_ 。 | | <em> | 代表_强调_ 文字。 | | <strong> | 代表_特别重要_ 文字。 | | <span> | 代表一段没有特殊含义的文本,当其他语义元素都不适合文本时候可以使用该元素。 | | <br> | 代表_换行_ 。 |

<img> | 代表一张_图片_ 。 | | <iframe> | 代表一个_内联的框架_ 。 | | <form> | 代表一个_表单_ ,由控件组成。 |

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2019-08-05 ,如有侵权请联系 cloudcommunity@tencent.com 删除

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前端入门系列之HTML
    • HTML是什么
      • 元素
      • 嵌套元素
      • 块级元素,内联元素和可变元素
      • 空元素
    • 文档详解
      • HTML5 标签列表
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档