前端三剑客之HTML详解(上)

简介: HTML5是构建Web内容的一种语言描述方式。HTML5是互联网的下一代标准,是构建以及呈现互联网内容的一种语言方式.被认为是互联网的核心技术之一。

简介

    超文本标记语言(英语:HyperText Markup Language,简称:HTML)是一种用于创建网页的标准标记语言。

    HTML产生于1990年,1997年HTML4成为互联网标准,并广泛应用于互联网应用的开发。HTML5是Web中核心语言HTML的规范,用户使用任何手段进行网页浏览时看到的内容原本都是HTML格式的,在浏览器中通过一些技术处理将其转换成为了可识别的信息。

HTML预览

浅析html,.css,js区别

  • html

用于勾勒出网页的结构和内容

  • CSS

用于美化网页

  • JavaScript

让网页呈现动态的数据和效果

基础

声明

为了让浏览器识别html版本,正确显示网页。减少中文乱码等问题。

声明不区分大小写。

HTML5
<!DOCTYPE html>
html 4.01
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd">
html 1.0
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

对于中文网页需要使用 <meta charset="utf-8"> 声明编码,否则会出现乱码。有些浏览器(如 360 浏览器)会设置 GBK 为默认编码,但是,只要在HTML文件里写了<!doctype hmtl>和 <meta charset="utf-8" />,浏览器将会按照utf-8编码解析网页。

不过,一定要确保文档编码和meta设置的编码,一定要相同。比如,在记事本保存时,选择编码为utf-8,保存。(代码无需变动)。另一种,改变方式可以变动meta中所设置的编码和文档编码保持一致。

utf-8和utf8的区别

"UTF-8" 是标准写法,php 在 Windows 下边英文不区分大小写,所以也可以写成 "utf-8"。"UTF-8" 也可以把中间的"-"省略,写成 "UTF8"。

在数据库中只能使用"utf8"(MySQL) 在MySQL的命令模式中只能使用"utf8",不能使用"utf-8",也就是说在PHP程序中只能使用 "set names utf8(不加小横杠)",如果你加了"-"此行命令将不会生效,但是在 PHP 中 header 时却要加上"-"

<?php header('Content-Type: text/html; charset=UTF-8'); ?>

除了在命令 "mysql_query(set names utf8)" 外一律用大写"UTF-8"。

HTML标签

HTML标签对于大小写不敏感:<P>等同于<p>。

  • HTML 标签是由尖括号包围的关键词,比如
  • 标签分为开放标签和闭合标签。
  • HTML 标签通常是成对出现的,但也有例外,<br>和</br>这两个都是单独存在的,本身也都是开放标签和闭合标签,不包含内容,所以只是个标签。

<标签>内容<标签>

单标签 等于无内容的双标签

<student/>

双标签

<student "id=""uid"></student>

浏览器并不会直接显示HTML标签,但是通过标签来决定如何展示HTML页面的内容.

标题

标题(Heading)是通过 <h1> - <h6> 标签进行定义的。

<h1>hello</h1>
<h2>hello</h2>

尽量不要使用标题这个标签来生成粗体或者大号字体,这种可能会打乱原有的文档结构。

段落

<p>标签(块级元素)

HTML可以将文档分成若干段落。

折行,不产生新段落的情况下进行换行,可以借助<br>标签

<p>hello</p>
<p>你好<br>bob</p>

注释

可以将注释插入 HTML 代码中,这样可以提高其可读性,使代码更易被人理解。浏览器会忽略注释,也不会显示它们。

<!--这是注释-->

水平线

<hr>标签在HTML页面中创建水平线,可以用于分隔内容。

<h1>hello</h1>
<hr>
<h1>world</h1>

文本格式化标签

       一些 HTML 标签除了具有一定的语义(含义)外,还有默认的样式,例如<b>(加粗),通过这些标签我们无需借助 CSS 就可以为网页中的内容定义样式。在这些具有语义和默认样式的标签中,有许多是针对文本的,通过这些标签我们可以格式化文本(为文本添加样式),例如使文本加粗、倾斜或者添加下划线等。

文本格式化标签

标签

描述

<b>...</b>

加粗标签中的字体

<em>...</em>

强调标签中的内容,并使标签中的字体倾斜

<i>...</i>

定义标签中的字体为斜体

<small>...</small>

定义标签中的字体为小号字体

<strong>...</strong>

强调标签中的内容,并将字体加粗

<sub>...</sub>

定义下标文本

<sup>...</sup>

定义上标文本

<ins>...</ins>

定义文档的其余部分之外的插入文本

<del>...</del>

在文本内容上添加删除线

<code>...</code>

定义一段代码

<kbd>...</kbd>

用来表示文本是通过键盘输入的

<samp>...</samp>

定义程序的样本

<var>...</var>

定义变量

<pre>...</pre>

定义预格式化的文本,被该标签包裹的文本会保留所有的空格和换行符,字体也会呈现为等宽字体

<abbr>...</abbr>

用来表示标签中的内容为缩写形式

<address>...</address>

用来定义文档作者的联系信息,被该标签包裹的文本通常会以斜体呈现,并在文本前面换行

<bdo>...</bdo>

定义标签中的文字方向

<blockquote>...</blockquote>

定义一段引用的文本,例如名人名言,文本会换行输出,并在左右两边进行缩进

<q>...</q>

定义一段短的引用,浏览器会将引用的内容使用双引号包裹起来

<cite>...</cite>

表示对某个文献的引用,例如书籍或杂志的名称,文本会以斜体显示

<dfn>...</dfn>

用来定义一个术语,标签中的文本会以斜体呈现

关于 <b> 和 <strong>

在显示上,这两个标签都可是加粗文本,呢么为什么会有两个功能"相同"的标签呢?而且好像 strong 并非个例。

  • 首先,这两个并非完全相同。比如,如果使用网页阅读器阅读网页(盲人使用),strong 会重读,b 则不会。
  • 其次,从起源上来说,strong 是为了在未来建设语义网而诞生的。应该知道的是,html 是负责显示的标记,不能表示语义。也就是说,浏览器知道这个标签如何显示,而不知道标签所标记的内容应该是什么含义。而 strong 在语义上走出了第一步。

示例:

<b>这个文本是加粗的</b>
<br />
<strong>这个文本是加粗的</strong>
<br />
这个文本包含
<sub>下标</sub>
<br />
这个文本包含
<sup>上标</sup>
<br>
<del>这是删除线</del>
<br>
 <p>前面是宋体,<dfn>后面是斜体</dfn></p>

超链接

       HTML 使用超级链接与网络上的另一个文档相连。几乎可以在所有的网页中找到链接。点击链接可以从一张页面跳转到另一张页面。

<a>标签来设置超文本链接,在标签<a> 中使用了href属性来描述链接的地址。

<a href="链接地址">链接文本</a>
<a href="#">回到顶部</a>

链接文本不一定是要文本,可以是图片,HTML其他元素都行。

  • target属性

使用 target 属性,你可以定义被链接的文档在何处显示。

  1. target="_blank":在新窗口中浏览新的页面。
  2. target="_self":在同一个窗口打开新的页面。
  3. target="_parent":在父窗口中打开新的页面。(页面中使用框架才有用)
  4. target="_top" :以整个浏览器作为窗口显示新页面。(突破了页面框架的限制)
<a href="https://www.baidu.com/" target="_blank"
rel="noopener noreferrer">访问百度!</a>
<p>如果你将 target 属性设置为"_blank";, 链接将在新窗口打开,同时
加上rel="noopener noreferrer"意思是不会打开其他的网站,
因为恶意病毒可能会修改你的浏览器空白页地址。。</p>


  • id属性

id 属性可用于创建一个 HTML 文档书签.(注意,id不能重复)

书签不会以任何特殊方式显示,即在 HTML 页面中是不显示的。

在HTML文档中插入ID:

<a id="tips">有用的提示部分</a>

在HTML文档中创建一个链接到"有用的提示部分(id="tips")":

<a href="#tips">访问有用的提示部分</a>

或者,从另一个页面创建一个链接到"有用的提示部分(id="tips")":

<a href="https://www.baidu.com/html/html-links.html#tips">访问有用的提示部分</a>

注意:

请始终将正斜杠添加到子文件夹。一般情况,依赖服务器配置。

  1. 主要问了区分访问的是文件还是文件夹,比如访问路径为http://www.a.com/b浏览器不知道访问的是文件还是文件夹,会先访问一遍确认是那种类型,如果是文件夹则会加上/,重新访问地址为http://www.a.com/b/的路径。
  2. 如果带后缀名http://www.a.com/b.html可以明确知道访问的是文件,不需要再次请求。

图像

<img>标签

图像由<img> 标签定义。

<img> 是空标签,只包含属性,并且没有闭合标签。
源属性(src)

源属性的值就是图像的URL地址

Alt属性

图像定义一串预备的可替换的文本。

在浏览器无法载入图像时,替换文本属性告诉读者她们失去的信息。此时,浏览器将显示这个替代性的文本而不是图像。为页面上的图像都加上替换文本属性是个好习惯,这样有助于更好的显示信息,。

高度和宽度属性

height(高度)与width(宽度)属性用于设置图像的高度与宽度。

<img src="http://www.a,com/images/a.jpg" alt="error"

width="400px" height="400">

绝对路径与相对路径

1绝对路径

从盘符开始写出图片的绝对路径

C:/images/1.jpg或者/home/soft01/images/1.jpg

缺点

1.路径过长

2.不方便迁移,路径易报错。

2相对路径

只需要写出图片和网页的相对位置。方便迁移,简单。

1.平级 (同目录下)<img src="i.jpg">

2.下级          <img src="image/2.jpg">

3.上级         <img src="../3.jpg">

(照片最好全放到一个文件下里,使用上级最方便)

(然后统一放到src下)

<img src="../images/4.jpg">

<map>标签

<map> 标签用于客户端图像映射。

图像映射指带有可点击区域的一幅图像。

<img>中的 usemap 属性可引用 <map> 中的 id 或 name 属性(取决于浏览器),所以我们应同时向 <map> 添加 id 和 name 属性。

area 元素永远嵌套在 map 元素内部

area 元素可定义图像映射中的区域。

<img src="planets.gif" width="145" height="126" alt="Planets"
usemap="#planetmap">
<map name="planetmap">
  <area shape="rect" coords="0,0,82,126" href="sun.htm" alt="Sun">
  <area shape="circle" coords="90,58,3" href="mercur.htm" alt="Mercury">
  <area shape="circle" coords="124,58,8" href="venus.htm" alt="Venus">
</map>
//shape指的是点击区域的形状,
coords指的应该是链接区域在图片中的坐标(像素为单位)

表格

表格由 <table> 标签来定义。

  • table 表格声明范围
  • tr 行
  • td 行里的单元格
  • tr 声明表头

表格中的标签

标签

描述

<table>

定义表格

<th>

定义表格的表头

<tr>

定义表格的行

<td>

定义表格单元

<caption>

定义表格标题

<colgroup>

定义表格列的组

<col>

定义用于表格列的属性

<thead>

定义表格的页眉

<tbody>

定义表格的主体

<tfoot>

定义表格的页脚

实例:

<table border="1"cellspacing="0" width="30%" >
<caption>单元格间距</caption>
    <tr>
        <td>alice</td>
        <td>bob</td>
    </tr>
    <tr>
         <td>cc</td>
         <td>dd</td>
     </tr>
</table>
<table border="1" cellpadding="0" width="30%" >
<caption>单元格边距</caption>
    <tr>
        <td>Alice</td>
        <td>Bob</td>
    </tr>
  <tr>
         <td>cc</td>
         <td>dd</td>
     </tr>
</table>
<table border="1">
    <tr>
        <td rowspan="2" >alice</td>
        <td>bob</td>
    </tr>
    <tr>
        <td>cc</td>
    </tr>
</table>
<table border="1">
    <tr>
        <td colspan="2">bob</td>
    </tr>
    <tr>
        <td >alice</td>
        <td>cc</td>
    </tr>
</table>
<table border="1">
  <caption>带有标题的表格</caption>
  <tr>
    <th>A</th>
    <th>B</th>
  </tr>
</table>
<table border="1">
<caption>多元化的表格</caption>
<tr>
  <td>
   <p>这是一个段落</p>
   <p>这是另一个段落</p>
  </td>
  <td>这个单元格包含一个表格:
   <table border="1">
<caption>表格中的表格</caption>
   <tr>
     <td>A</td>
     <td>B</td>
   </tr>
   <tr>
     <td>C</td>
     <td>D</td>
   </tr>
   </table>
  </td>
</tr>
<tr>
  <td>这个单元格包含一个列表
   <ul>
    <li>apples</li>
    <li>bananas</li>
    <li>pineapples</li>
   </ul>
  </td>
  <td>HELLO</td>
</tr>
</table>

框架

通过使用框架,你可以在同一个浏览器窗口中显示不止一个页面。

iframe标签

  • height 和 width 属性用来定义iframe标签的高度与宽度。
  • frameborder 属性用于定义iframe表示是否显示边框,设置属性值为"0"可移除
<iframe src="demo_iframe.htm" name="iframe_a"></iframe>
<p><a href="https://www.runoob.com" target="iframe_a">
 RUNOOB.COM</a></p>
<p>因为 a 标签的 target 属性是名为
 iframe_a 的 iframe 框架,
 所以在点击链接时页面会显示在 iframe框架中。</p>


网页对于嵌套的设置:

X-Frame-Options

这个有三个可配置值

  • DENY:表示该网站页面不允许被嵌套,即便是在自己的域名的页面中也不能进行嵌套。
  • SAMEORIGIN:表示该页面可以在相同域名页面中被嵌套展示。
  • ALLOW-FROM uri:表示该页面可以在指定来源页面中进行嵌套展示。

脚本标签

<script>标签

  • <script> 标签用于定义客户端脚本。
  • <script> 元素既可包含脚本语句,也可通过 src 属性指向外部脚本文件。

<noscript>标签

  • <noscript> 标签提供无法使用脚本时的替代内容,比方在浏览器禁用脚本时,或浏览器不支持客户端脚本时。
  • <noscript>元素可包含普通 HTML 页面的 body 元素中能够找到的所有元素。
  • 只有在浏览器不支持脚本或者禁用脚本时,才会显示 <noscript> 元素中的内容:
<script>
document.write("Hello World!")
</script>
<noscript>抱歉,你的浏览器不支持 JavaScript!</noscript>

目录
相关文章
|
18天前
|
前端开发 JavaScript 搜索推荐
HTML与CSS在Web组件化中的核心作用及前端技术趋势
本文探讨了HTML与CSS在Web组件化中的核心作用及前端技术趋势。从结构定义、语义化到样式封装与布局控制,两者不仅提升了代码复用率和可维护性,还通过响应式设计、动态样式等技术增强了用户体验。面对兼容性、代码复杂度等挑战,文章提出了相应的解决策略,强调了持续创新的重要性,旨在构建高效、灵活的Web应用。
29 6
|
2月前
|
XML 前端开发 JavaScript
前端开发进阶:从HTML到React.js
【10月更文挑战第9天】前端开发进阶:从HTML到React.js
|
3月前
|
Web App开发 存储 移动开发
前端基础(十七)_HTML5新特性
本文概述了HTML5的关键新特性,包括canvas图形绘制、多媒体的`video`和`audio`元素、本地存储功能、语义化标签(如`header`、`footer`、`nav`等)及其新增表单控件和属性(如`url`、`email`、`date`类型输入框等)。这些改进增强了网页的功能性和用户体验。
47 1
前端基础(十七)_HTML5新特性
|
2月前
|
前端开发 JavaScript 数据安全/隐私保护
【前端基础篇】HTML零基础速通2
【前端基础篇】HTML零基础速通
21 2
|
2月前
|
Web App开发 移动开发 前端开发
【前端基础篇】HTML零基础速通1
【前端基础篇】HTML零基础速通
33 1
|
3月前
|
前端开发 程序员
【前端web入门第二天】01 html语法实现列表与表格_合并单元格
本文介绍了HTML中的列表与表格的使用方法。列表包括无序列表(`&lt;ul&gt;`嵌套`&lt;li&gt;`)、有序列表(`&lt;ol&gt;`嵌套`&lt;li&gt;`)和定义列表(`&lt;dl&gt;`嵌套`&lt;dt&gt;`和`&lt;dd&gt;`)。
68 19
|
3月前
|
前端开发
前端基础(二)_HTML常用标签(块级标签、行级标签、行块级标签)
本文详细介绍了HTML中的常用标签,包括块级标签(如`h1`至`h6`、`p`、`div`等)、行级标签(如`span`、`b`、`strong`、`i`、`em`、`sub`、`sup`、`del`、`a`等),以及行块级标签(如`img`)。文章解释了这些标签的用途、特点和基本用法,并通过示例代码展示了如何在HTML文档中使用它们。
162 1
|
3月前
|
前端开发 Windows
【前端web入门第一天】02 HTML图片标签 超链接标签 音频标签 视频标签
本文档详细介绍了HTML中的图片、超链接、音频和视频标签的使用方法。首先讲解了`&lt;img&gt;`标签的基本用法及其属性,包括如何使用相对路径和绝对路径。接着介绍了`&lt;a&gt;`标签,用于创建超链接,并展示了如何设置目标页面打开方式。最后,文档还涵盖了如何在网页中嵌入音频和视频文件,包括简化写法及常用属性。
57 13
|
3月前
|
前端开发 程序员 C++
【前端web入门第一天】01 开发环境、HTML基本语法文本标签
本文档详细介绍了HTML文本标签的基础知识。首先指导如何准备开发环境,包括安装VSCode及常用插件;接着全面解析HTML的基本结构与标签语法,涵盖从基本骨架搭建到注释的使用,以及标题、段落、换行和平行线、文本格式化等标签的具体应用,适合初学者循序渐进地掌握HTML。
|
3月前
|
移动开发 前端开发 JavaScript
使用html-to-image代替html2canvas,结合jspdf实现下载pdf(下载截图下载前端dom元素)
本文介绍了在前端项目中,当使用`html2canvas`遇到问题时,如何使用`html-to-image`库作为替代方案,结合`jspdf`实现将DOM元素生成为PDF文件并提供下载。文章首先讨论了`html2canvas`可能遇到的问题,并提供了该库的使用示例代码。随后,详细介绍了`html-to-image`库的安装和使用方法,展示了如何将DOM元素转换为Canvas,再利用`jspdf`生成PDF文件。最后,文章通过示例代码说明了整个转换和下载的过程,并展示了效果截图。
149 0