首页 > Web开发 > 详细

前端html

时间:2019-12-03 16:42:12      阅读:444      评论:0      收藏:0      [点我收藏+]

HTML

web标准

  • w3c:万维网联盟组织,用来制定web标准的机构
  • web标准:制作网页遵循的规范
  • web标准的规范:结构标准,表现标准,行为标准
  • 结构:html 表示:css 行为:javascript(js)

总结说明:

  • 结构标准:相当于人的骨架。html就是用来制作网页的。
  • 表现标准:相当于人的衣服。css是用来给网页进行美化的。
  • 行为标准:相当于人的动作。JS就是让网页动起来,具有生命力

浏览器介绍:

强烈推荐:

浏览器 内核
火狐浏览器 gecko
谷歌浏览器 blink

PS:「浏览器内核」也就是浏览器所采用的「渲染引擎」,渲染引擎决定了浏览器如何显示网页的内容以及页面的格式信息。

总结:渲染引擎是兼容性问题出现的根本原因。

开发工具

  • Visual Studio Code
  • WebStorm
  • Sublime text
  • PyCharm
  • ....

html介绍

html全称(HyperText Markup Language): 超文本标记语言,不是一种编程语言。

是一种描述性的标记语言,用来描述超文本的显示方式。比如字体,颜色,大小等。

  • 超文本:音频,视频,图片称为超文本
  • 标记:<英文单词或字母>称为标记,一个html页面都是由各种标记组成

作用:html是负责描述文档语义的语言

注意:HTML语言不是编程语言,而是一个标记语言(没有编译过程),html页面直接由浏览器解析执行

HTML只是负责描述文档语义的语言,在html中,除了语义,其他什么都没有。

html是一个纯本文文件(就是用txt文件改名而成),用一些标签来描述文字的语义,这些标签在浏览器里面是看不到的,所以称为“超文本”,所以就是“超文本标记语言”了。

HTML术语

  • 网页:由各种标记组成的页面就叫网页
  • 主页(首页):一个网站的起始页面或者导航页面
  • 标记:<p>称为开始标记,</p>称为结束标记,也叫标签。每个标签都规定好了特殊的含义
  • 元素:<p>内容<p>称为元素
  • 属性:给每一个标签所做的辅助信息

HTML规范

  • html是一个弱势语言
  • 区分大小写
  • 页面的后缀是html或者htm
  • HTML的结构:
    • 声明部分:主要的作用是:用来告诉浏览器这个页面使用的是什么标准。是HTML5标准
    • head部分:将页面的一些额外信息告诉浏览器。不会显示在页面上
    • boby部分:我们所写的需要显示出来的代码必须放在次标签内

编写html的规范

  1. 所有的标签都必须正确的嵌套,不能交叉嵌套。正确的写法:<h1><font></font></h1>
  2. 所有的标记必须小写
  3. 所有的标记都必须有关闭
    • 双边标记 有开始就有闭合。例如<span></span>
    • 单边标记 只有一个标记自闭和。例如:<br> 转成<br />,<hr>转成<hr \>,<img src="url" />
  4. 所有的属性值都必须添加引号。<h1 id="head"> </h1>
  5. 所有的属性必须有值。<input type="radio" checked="checked">

HTML的基本语法特征

html对换行不敏感,对tab不敏感

html只在乎标签的嵌套结构,嵌套的关系。和换行 tab无关

也就是说html不是靠缩进来表示嵌套的,就是看标签的包裹关系。但是有良好的缩进,代码更易读。建议缩进

空白折叠线下

HTML中所有的文字之间,如果有换行/空格/tab都将被折叠为一个空格显示

标签要严格封闭

<html></html> <meta />

html结构

新建html文件,输入html:5 或者! 然后按tab键后,自动生成的代码如下:

<!doctype html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport"
          content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
</head>
<body>

</body>
</html>

文档声明头

在任何一个标准的html页面,第一行一定是以一个以<!doctype html>开头

这一行,就是文档声明头,(DocType Declaration),简称DTD。此标签可告知浏览器文档使用哪种HTML或XHTML规划

DOCTYPE

头标签(head)

head标签都放在头部分之间。这里面包含:‘ <meta> <link> <style>‘</p> <pre class="html"><code><title> <!-- 指定整个网页的标题,在浏览器最上方显示--> <meta> <!-- 提供有关页面的基本信息 --> <link> <!-- 定义文档与外部资源的关系 --> <style> <!-- 定义内部样式表与网页的联系 --></code></pre> <h4 id="meta标签">Meta标签</h4> <p>元素可提供有关页面的元信息(meta-infomation),针对搜索引擎和更新频度的描述和关键词</p> <p>标签位于文档的头部,不包含任何内容</p> <p>提供的信息是用户不可见的。meta标签的组成:meta标签共有两个属性,他们分别是<code>http-equiv</code>属性和<code>name</code>属性,不同的属性又有不同的参数值,这些不同的参数值就实现了不同的网页功能。</p> <p>常见的meta标签</p> <h5 id="http-equiv属性">http-equiv属性</h5> <p>它用来向浏览器传达一些有用的信息,帮助浏览器正确的显示网页内容,与之对应的是content,content中的内容其实就是各个参数的变量值</p> <pre class="html"><code><!-- 重定向 2秒后跳转到指定的网址 注意分号 --> <meta http-equiv="refresh" content="2;url=http://www.baidu.com"> <!-- 指定文档的内容类型和编码类型 --> <meta http-equiv="Content-Type" content="text/html;charset=utf-8"> <!-- 告诉IE浏览器以最高级模式渲染当前网页 --> <meta http-equiv="x-ua-compatible" content="IE=edge"></code></pre> <h5 id="name属性">name属性</h5> <p>主要用于页面的关键字和描述,是写给搜索引擎看的,关键字可以有多个用逗号(,)隔开,与之对应的属性值为content,content中的内容主要是便于搜索引擎机器人查找信息和分类信息的。</p> <table> <thead> <tr class="header"> <th style="text-align: center;">值</th> <th>描述</th> </tr> </thead> <tbody> <tr class="odd"> <td style="text-align: center;">application-name</td> <td>规定页面所代表的web应用程序的名称</td> </tr> <tr class="even"> <td style="text-align: center;">author</td> <td>规定文档的作者的名称</td> </tr> <tr class="odd"> <td style="text-align: center;">description</td> <td>规定页面的描述。搜索引擎会把这个描述显示在搜索结果中</td> </tr> <tr class="even"> <td style="text-align: center;">generator</td> <td>规定用于生成文档的一个软件包(不用于手写页面)</td> </tr> <tr class="odd"> <td style="text-align: center;">keywords</td> <td>规定一个逗号分割的关键字列表 - 相关的网页(告诉搜索引擎页面是与什么相关的 提示:总是规定关键词(对于搜索引擎进行页面分类是必要的)</td> </tr> </tbody> </table> <pre class="html"><code><!-- 告诉搜索引擎,这个网页的作用,可以提高搜索命中率。让别人更容易找到你的网页 --> <meta name="Keywords" content="百度,网易,搜狐,微博"> <!-- 设置Description页面描述,那么百度搜索结果,就能够显示这些语句,这个技术称为SEO (Search Engine Optimization) 搜索引擎优化 --> <meta name="Description" content="网易是中国领先的互联网技术公司,为用户提供免费邮箱、游戏、搜索引擎服务,开设新闻、娱乐、体育等30多个内容频道,及博客、视频、论坛等互动交流,网聚人的力量。" /> <!-- 网页支持移动端,移动设备优先 --> <meta name="viewport" content="width=device-width, initial-scale=1"></code></pre> <p><strong>效果如下:</strong></p> <p><img alt="技术分享图片" src="C:\Users\31263\Desktop\TIM截图20191014184058.png" alt="TIM截图20191014184058" /></p> <h4 id="title标签">title标签</h4> <p>主要的作用是告诉用户和搜索引擎网页的主要内容,搜索引擎可以通过网页标题,迅速的判断出当前网页的主题</p> <pre class="html"><code><title>马海阳大本营</title></code></pre> <p><img alt="技术分享图片" src="C:\Users\31263\AppData\Roaming\Typora\typora-user-images\1571050218121.png" alt="1571050218121" /></p> <h2 id="html颜色的显示">html颜色的显示</h2> <p><strong>光谱三原色</strong></p> <h3 id="颜色的表示">颜色的表示</h3> <p>有三种方法:</p> <ul> <li>纯单词表示:red green blue orange gray等</li> <li>10进制表示:rgb(255,0,0)</li> <li>16进制表示:#FF0000 #0000FF #00FF00等等</li> </ul> <p>RGB色彩模式:</p> <ul> <li>RGB各有256级(0-255)亮度,256级的RGB色彩总共能组合出约1678万种色彩,即256×256×256=16777216。</li> <li>在数字视频中,对RGB三基色各进行8位编码就构成了大约1678万种颜色,这就是我们常说的真彩色。所有显示设备都采用的是RGB色彩模式。</li> <li>RGB三原色也叫加色模式,这是因为当我们把不同光的波长加到一起的时候,可以得到不同的混合色。例:红+绿=黄色,红+蓝=紫色,绿+蓝=青</li> <li>自然界中所有的颜色都可以用红、绿、蓝(RGB)这三种颜色波长的不同强度组合而得,这就是人们常说的三原色原理。</li> </ul> <p><a href="https://htmlcolorcodes.com/zh/yanse-ming/">颜色码对照表</a></p> <h2 id="html标签">html标签</h2> <h3 id="html标签分类">html标签分类</h3> <p>html标签又称为html元素,它分为<strong>块级元素</strong>和<strong>内联元素</strong>(行内元素),都是html规范中的概念</p> <table> <thead> <tr class="header"> <th>标题</th> <th>列表</th> <th>排版标签</th> <th>表格</th> <th>表单</th> </tr> </thead> <tbody> <tr class="odd"> <td>h1</td> <td>ol</td> <td>p</td> <td>table</td> <td>form</td> </tr> <tr class="even"> <td>h2</td> <td>ul</td> <td>div</td> <td></td> <td></td> </tr> <tr class="odd"> <td>h3</td> <td>li</td> <td>hr</td> <td></td> <td></td> </tr> <tr class="even"> <td>h4</td> <td>dl</td> <td>center</td> <td></td> <td></td> </tr> <tr class="odd"> <td>h5</td> <td>dt</td> <td>pre</td> <td></td> <td></td> </tr> <tr class="even"> <td>h6</td> <td>dd</td> <td></td> <td></td> <td></td> </tr> </tbody> </table> <h4 id="标题h1-h6">标题(h1-h6)</h4> <p>标题使用<code>h1-h6</code>标签来进行定义。<code><h1></code>定义最大的标题,<code><h6></code>定义最小的标题。具有align属性,属性值可以是:left center right</p> <pre class="html"><code><h1 align="center">一级标题</h1> <h2 align="left">二级标题</h2> <h3 align="right">三级标题</h3> <h4>四级标题</h4> <h5>五级标题</h5> <h6>六级标题</h6></code></pre> <p><strong>效果</strong>:</p> <p><img alt="技术分享图片" src="C:\Users\31263\AppData\Roaming\Typora\typora-user-images\1571051475700.png" alt="1571051475700" /></p> <h4 id="列表">列表</h4> <p>列表分为三种,有序列表ol,无序列表ul和定义列表dl。其中ol和ul必须结合li使用,而dl则必须结合dt,dd使用</p> <ul> <li>ol (ordered list) 有序列表 <ul> <li>li list item 列表项</li> </ul></li> <li>ul (unordered list) 无序列表 <ul> <li>li list item 列表项</li> </ul></li> <li>dl (definition list) 定义列表 <ul> <li><code><dt></code>: definition title列表的标题,这个标签是必须的</li> <li><code><dd></code>: definition description 列表的列表项,如果不需要可以不加</li> </ul></li> </ul> <p>需要注意的地方:</p> <p>li不能单独存在,必须包裹在ul或者ol里边;反过来说 ul的“儿子”不能是别的东西,只能有li。</p> <p>我们这里再次强调,ul或者ol的作用,并不是给文字增加小圆点的,而是增加列表是否有序的“语义”的,因此不能省略。</p> <h5 id="ol标签-有序列表">ol标签 有序列表</h5> <p>代码示例:</p> <pre class="html"><code><ol type="1"> <li>大大</li> <li>小小</li> <li>cc</li> </ol></code></pre> <p>type属性:</p> <p>? 1/a/A/i/I 有五个属性分别意思为:1阿拉伯数字排序/a小写字母排序/A大写字母排序/i按i的数量排序/I按I的数量排序</p> <h5 id="ul标签-无序列表">ul标签 无序列表</h5> <p>代码示例:</p> <pre class="html"><code><ul type="disc"> <li>大大</li> <li>小小</li> <li>cc</li> </ul> </code></pre> <p>type属性:</p> <ul> <li>disc:实心原点 默认</li> <li>square:实心放点</li> <li>circle:空心圆</li> <li>none:无符号</li> </ul> <h5 id="dl标签-定义列表">dl标签 定义列表</h5> <p><strong>作用很大</strong></p> <p>示例代码:</p> <pre class="html"><code><dl> <dt>第一题</dt> <dd>你恋爱了吗</dd> <dd>你失恋了吗</dd> <dt>第二题</dt> <dd>你成功了吗</dd> <dd>你失败了吗</dd> </dl> </code></pre> <p>定义列表表达的语义是两层</p> <ul> <li>是一个列表,列出几个dd项目</li> <li>每一个词儿都有自己的描述项</li> </ul> <p>备注:dd是用来描述dt的</p> <p>定义列表用法非常灵活,可以一个dt配很多dd</p> <p>还可以拆开,每一个dl只有一个dt和dd,这样清晰很多了</p> <p><strong>京东案例(京东首页最下方) </strong><img alt="技术分享图片" src="http://image.bubuko.com/info/201912/20191203164212565764.png" alt="img" /></p> <p>PS:dd和dt都是容器级标签,放什么都可以。所以,应该更清晰的知道:<strong>用什么标签,不是通过样子来决定,而是通过语义(语义本质是结构)</strong></p> <h4 id="排版标签">排版标签</h4> <h5 id="p">p</h5> <p>段落标签<code><p></code>(paragraph)</p> <p><strong>属性:</strong></p> <ul> <li>align=‘属性值‘:对齐方式。属性值包括 left right center</li> </ul> <p>代码示例:</p> <pre class="html"><code><p>这是一个段落</p> <p align="center">这是另一个段落</p> </code></pre> <p>PS:HTML标签是分等级的。HTML将所有的标签分为两种</p> <ul> <li>文本级标签:p span a b i u em 文本标签里只能放文字 图片 表单元素</li> <li>容器级标签:div h系列 li dt dd 容器标签里可以放任何东西</li> </ul> <p>从学习p的第一天开始,就要死死记住:<strong>p标签是一个文本级标签,p里边只能放文字 图片 表单元素</strong>。其他的一律不能放</p> <p>错误写法:</p> <pre class="html"><code><p> 我是一个段落 <h1>我是一个一级标题</h1> </p> </code></pre> <p>浏览器不允许你这么做。我们使用Chrome的F12审查元素发现,浏览器自己把p封闭掉了,不让你去包裹h2。</p> <p>PS:Chrome浏览器是世界上HTML5支持最好的浏览器。提供了非常好的开发工具,非常适合我们开发人员使用。审查元素功能的快捷键是F12。</p> <h4 id="div">div</h4> <p>div和span是非常重要的标签,div的语义是division"分割";</p> <p>css中这标签是最重要的<strong>盒子</strong></p> <p>div:把标签中的内容作为一个块来对待(division)。必须独占一行</p> <p>div标签的属性:</p> <ul> <li>aligan="属性值":设置块的位置。属性值可选择:left center right</li> </ul> <p>如果单独在页面中插入这两个元素,不会对页面产生任何的影响。这两个元素是专门为css定义样式而生的。div+css来实现各种样式</p> <p>示例代码:</p> <pre class="html"><code><div> 导航栏 </div> <div> 中心 </div> </code></pre> <p>div在浏览器中,除了换行以外,默认不会有任何的效果,但是语义变了,div中所有的小元素是一个小区域</p> <p>div标签是一个容器标签,里边什么都可以放,甚至可以放div自己</p> <p>示例代码:</p> <pre class="html"><code><div class="header"> <div class="logo"></div> <div class="nav"></div> </div> <div class="content"> <div class="guanggao"></div> <div class="shop"></div> </div> <div class="fonter"></div> </code></pre> <p>所以,我们亲切的称呼这种模式叫做<strong>div+css</strong>。<strong>div标签负责布局,负责结构,负责分块。css负责样式</strong></p> <p>ps:这个class和css有很大的关系</p> <h4 id="hr">hr</h4> <p>水平分割线(horizontal rule)可以在视觉上将文档分割成各个部分</p> <p>代码示例:</p> <pre class="html"><code><p>介绍</p> <hr> <hr> </code></pre> <h4 id="内容居中标签-center">内容居中标签 <code><center></code></h4> <p>此时center表示一个标签,而不是一个属性。只要在这个标签里面的内容,都会居于浏览器的中间</p> <p>示例代码:</p> <pre class="html"><code><center> <p>小马哥</p> </center> </code></pre> <p>在h5中,center标签不建议使用</p> <h4 id="预定义预格式化标签pre">预定义(预格式化)标签:<code><pre></code></h4> <p>将保留其中的所有空白字符(空格 换行符),原封不动的输出结果(告诉浏览器不要忽略空格和换行)</p> <p>说明:真正的网页排版过程中,pre标签几乎用不着。但在php中用于打印一个数组时使用</p> <p>示例代码:</p> <pre class="html"><code><pre> 鹅鹅鹅 作者:李白 曲项向天歌 白毛浮绿水 </pre> </code></pre> <h4 id="表格标签table">表格标签(table)</h4> <p>表格标签用table表示</p> <p>一个表格是由表头<code><thead></code>和表格内容<code><tbody></code>组成的</p> <p>其中的每一行由<code><tr></code>组成的,每行中的每一格是由<code><td></code>组成的</p> <p>现在通过css定位的功能来实现,做页面的时候表格的作用还是有一些的</p> <pre class="html"><code><table> <thead> <th>id</th> <th>name</th> <th>age</th> </thead> <tbody> <tr> <td>1</td> <td>alex</td> <td>20</td> </tr> <tr> <td>2</td> <td>mhy</td> <td>20</td> </tr> </tbody> </table> </code></pre> <p>上面我们会发现表头中的文字是默认加粗的,这种样式我们后面可以通过css调整,所以表格中的表头部分省略也是可以的。</p> <p>下面这段代码就是省略了表头之后的表格样式(常用):</p> <pre class="html"><code><table> <tr> <td>小马哥</td> <td>18</td> <td>男</td> <td>山东</td> </tr> <tr> <td>小岳岳</td> <td>45</td> <td>男</td> <td>河南</td> </tr> <tr> <td>邓紫棋</td> <td>23</td> <td>女</td> <td>香港</td> </tr> </table> </code></pre> <p>上图中的表格好像没看到边框呀,不急,接下来看看<code><table></code>标签的属性。</p> <p><strong>属性:</strong></p> <ul> <li>border:边框。像素为单位</li> <li>style=" border-collapse:collapse; " :单元格的线和表格的边框线合并</li> <li>width:宽度。像素为单位</li> <li>height:高度。像素为单位</li> <li>bordercolor:表格的边框颜色</li> <li>align:<strong>表格</strong>的水平对齐方式。属性值可以填:left right center <ul> <li>注意:这里不是设置表格里内容的对齐方式,如果想设置内容的对齐方式,要对单元格标签`进行设置)</li> </ul></li> <li>cellpadding:单元格内容到边的距离,像素为单位。默认情况下,文字是紧挨着左边线的,则默认情况下为0 <ul> <li>注意不是单元格内容到四条边的距离哈,而是到一条边的距离,默认是与左边那条线的距离。如果设置属性<code>dir="rtl"</code>,那就指的是内容到右边那条线的距离。</li> </ul></li> <li>cellspacing:单元格和单元格之间的距离(外边距),像素为单位。默认情况下的值为0</li> <li>bgcolor="#99cc66":表格的背景颜色</li> <li>backgroud="路径src":背景图片 背景图片的优先级大于背景颜色</li> </ul> <p>备注:表格中很细表格边线的制作:</p> <p>CSS的写法:</p> <pre class="css"><code>style="border-collapse:collapse;" </code></pre> <h5 id="行-tr">行 tr</h5> <p>一个表格就是一行一行组成的嘛</p> <p><strong>属性</strong>:</p> <ul> <li>dir:公有属性,设置这一行单元格内容的排列方式。可以取值:ltr:从左到右(left to right,默认),rtl:从右到左(right to left)</li> <li>bgcolor:设置这一行的单元格的背景色</li> <li>height:一行的高度</li> <li>align="center":一行的内容水平居中显示,取值 left center right</li> <li>valign="center":一行的内容垂直居中,取值:top middle bottom</li> </ul> <h5 id="单元格-td">单元格 td</h5> <p><strong>属性:</strong></p> <ul> <li>align:内容的横向对齐方式。属性值可以填:left center right</li> <li>valign:内容的纵向对齐方式。属性值可以填:top middle bottom</li> <li>width:绝对值或者相对值(%)</li> <li>height:单元格的高度</li> <li>bgcolor:设置这个单元格的背景色</li> <li>backgroud:设置这个单元格的背景图片</li> </ul> <h5 id="单元格的合并">单元格的合并</h5> <p>如果要将两个单元格合并,那肯定要删除一个单元格</p> <p>单元格的属性:</p> <ul> <li>colspan:横向合并。例如:colspan="2" 表示当前单元格在水平方向占据两个单元格的位置</li> <li>rowspan:纵向合并。例如:rowspan="2" 表示当前单元格在垂直方向上占据两个单元格的位置</li> </ul> <h5 id="单元格加粗-th">单元格加粗 th</h5> <p>相当于<code><td>+<b></code></p> <p>属性同<code><td></code>标签一样</p> <h5 id="表格的标题使用时和tr标签并列-caption">表格的标题。使用时和tr标签并列 caption</h5> <h5 id="表格的thead标签-tbody标签-tfoot标签">表格的thead标签 tbody标签 tfoot标签</h5> <p>这三个标签有与没有的区别:</p> <ol> <li><p>如果写了,那么这三个部分的<strong>代码顺序可以随意</strong>,浏览器显示的部分还是按照thead tbody tfoot的顺序依次来显示内容。 如果不写thead、tbody、tfoot,那么浏览器解析并显示表格内容的时候是从按照代码的从上到下的顺序来显示。</p></li> <li><p>当表格非常大内容非常多的时候,如果用thead、tbody、tfoot标签的话,那么<strong>数据可以边获取边显示</strong>。如果不写,则必须等表格的内容全部从服务器获取完成才能显示出来。</p></li> </ol> <h3 id="块级元素">块级元素</h3> <p>块级元素是指本身属性为display:block;的元素。因为它自身的特点,我们通常使用块级元素来进行大布局(大结构)的搭建</p> <blockquote> <p>独占一行,每一个块级元素都会从新的一行重写开始。从上到下排布可以直接控制宽度,高度级盒子模型相关的css属性。</p> <p>在不设置宽度的情况下。块级元素的宽度是它父级元素内容的宽度</p> <p>在不设置高度的情况下。块级元素的高度是它本身内容的高度</p> </blockquote> <h3 id="内联元素">内联元素</h3> <table> <thead> <tr class="header"> <th></th> <th>字体</th> <th>排版</th> <th>超链接</th> <th>图片</th> </tr> </thead> <tbody> <tr class="odd"> <td>粗体</td> <td>b strong</td> <td>span</td> <td>a</td> <td>img</td> </tr> <tr class="even"> <td>斜体</td> <td>em i</td> <td>br</td> <td></td> <td></td> </tr> <tr class="odd"> <td>上下标</td> <td>sup sub</td> <td></td> <td></td> <td></td> </tr> <tr class="even"> <td>划线</td> <td>del/s u</td> <td></td> <td></td> <td></td> </tr> </tbody> </table> <p>内联元素是指本身属性为display:inline;的元素。因为它自身的特点,我们通常使用内联元素来进行文字/小图标(小构建)的搭建</p> <blockquote> <p>和其他内联元素从左到右在一行显示</p> <p>不能直接控制宽度/高度以及盒子模型的相关css属性,但是直接设置内外边距的左右值是可以的</p> <p>内联元素的宽高是由本身内容的大小决定(文本/图片等)</p> <p>内联元素只能容纳文本或其他内联元素(此处请注意,不要再内联元素中嵌套块级元素)</p> </blockquote> <h3 id="文本级和容器级">文本级和容器级</h3> <p>除此之外,从HTML的角度来讲,标签还可以分为<strong>文本级和容器级:</strong></p> <ul> <li>文本级标签:p span a b i u em</li> <li>容器及标签:div h系列 li dt dd</li> </ul> <p>文本及标签的意思是标签中可以放文本,不可以放其他内容。你会发现除了p之外,所有的文本级标签,都是行内元素。p是个文本级,但是是个块级元素</p> <p>PS:为甚么说p是文本级标签呢?因为p里面只能放文字&图片&表单元素,p里面不能放h和ul,p里面也不能放p。</p> <h3 id="html中的特殊字符">HTML中的特殊字符</h3> <ul> <li><code>&nbsp;</code>:空格 (non-breaking spacing,不断打空格)</li> <li><code>&lt;</code>:小于号(less than)</li> <li><code>&gt;</code>:大于号(greater than)</li> <li><code>&amp;</code>:符号<code>&</code></li> <li><code>&quot</code>:双引号</li> <li><code>apos;</code>:单引号</li> <li><code>&copy;</code>:版权<code>?</code></li> <li><code>&tarde;</code>:商标<code>?</code></li> </ul> <p>要求大家背过的特殊字符:?、<、>、&copy</p> <p>比如说,你想把<code>作为一个文本在页面上显示,直接写</code>是肯定不行的,因为这代表的是一个段落标签,所以这里需要用到<strong>转义字符</strong>。应该这么写:</p> <pre class="html"><code>这是一个HTML语言的&lt;p&gt;标签 </code></pre> <p>如果还想知道其它的HTML特殊字符:<a href="http://tool.chinaz.com/Tools/HtmlChar.aspx">HTML特殊字符参考表</a></p><p><a href="http://www.bubuko.com/infodetail-3315054.html" title="前端html,bubuko.com" style="color:#ffffff">前端html</a></p><p>原文:https://www.cnblogs.com/Anesthesia-is/p/11977376.html</p></span> </div> <script type="text/javascript"> bubuko_load('content_after');</script> <div id="divcomment"> <div> <div class=" divtextaligncenter"> <div class="detailcai" id="infono"> <div class="detailcai1 colorboldlv"> 踩</div> <div class="detailcai2 colorboldlv"> (<span id="spanNo">0</span>)</div> </div> <div class="detailzan" id="infoyes"> <div class="detailzan1 colorboldCheng"> 赞</div> <div class="detailzan2 colorboldCheng"> (<span id="spanYes">0</span>)</div> </div> <div class="divfloatclear"> </div> </div> <div class="divtextalignright margintop10"> <div class="width100bi paddingleft10right10"> <span id="spanYesContent" class="colorboldCheng"></span>  <span id="spanNoContent" class="colorboldlv"></span>  <span id="spanBadContent" class="colorboldCheng"> </span> </div> </div> </div> <div class="divtextalignright margintop10"> <span class="detailjubao" id="infobad">举报</span> </div> <script type="text/javascript"> bubuko_load('comment_before');</script> <div id="comment" class="divtextalignleft margintop20"> <div class="detailpinglun1"> <span class="detailpinglun2 title6">评论</span> <span class="detailpinglun3">一句话评论(<span id="commentCount" class="colorboldCheng">0</span>)</span> </div> <div class="paddingtop20"> <div id="commentlistend" name="commentlistend" class="divtextaligncenter margintop20"> <span id="lblpage"></span> </div> </div> <div class="margintop20"> <form method="post" action="/ajaxjs/info_detail_commentadd.aspx"> <div class="divtextalignleft paddingtop20"> <div id="commenthf" class="divbackgroundcolor1"> </div> <div> <textarea name="tbcommentcontent" id="tbcommentcontent" disabled="disabled" class="tb" style="width: 680px; height: 120px;" ></textarea> </div> </div> <div class="divtextalignright paddingtop10 " style="display:none;"> <span id="addCommentTishi" class="colorboldCheng">登录后才能评论!</span> <span id="loginno"><input type="button" class="mbtn1" value="登录" onclick="location.href='login.aspx?returnUrl='+document.URL.replace(new RegExp('&', 'g'), '(_)')" /></span> </div> </form> </div> </div> </div> <script type="text/javascript"> bubuko_load('comment_after');</script> </div> </div> <div class="width30bi divfloatright"> <div class="paddingbottom20"> <!-- <script type="text/javascript"> document.write(unescape('%3Cdiv id="bdcs"%3E%3C/div%3E%3Cscript charset="utf-8" src="http://znsv.baidu.com/customer_search/api/js?sid=10743263978424259100') + '&plate_url=' + (encodeURIComponent(window.location.href)) + '&t=' + (Math.ceil(new Date() / 3600000)) + unescape('"%3E%3C/script%3E'));</script> --> </div> <script type="text/javascript"> bubuko_load('right_top');</script> <div class="width100bi divborder"> <div class="divtitle"> <div id="infofile1_div1" class="divfloatleft divtitlefont"> 分享档案</div> <div class="divfloatright"> <a href="/infotimemore.html" title="分享档案更多" class="colorCheng">更多></a> </div> <div class="divfloatclear"> </div> </div> <div class="divtextalignleft paddingleft10right10 margintop10bottom10 heightline30px"> <a class="taga" href="/infotime-20210923-1.html" title="2021年09月23日技术分享文章"> 2021年09月23日 (328)</a><br /> <a class="taga" href="/infotime-20210924-1.html" title="2021年09月24日技术分享文章"> 2021年09月24日 (313)</a><br /> <a class="taga" href="/infotime-20210917-1.html" title="2021年09月17日技术分享文章"> 2021年09月17日 (191)</a><br /> <a class="taga" href="/infotime-20210915-1.html" title="2021年09月15日技术分享文章"> 2021年09月15日 (369)</a><br /> <a class="taga" href="/infotime-20210916-1.html" title="2021年09月16日技术分享文章"> 2021年09月16日 (411)</a><br /> <a class="taga" href="/infotime-20210913-1.html" title="2021年09月13日技术分享文章"> 2021年09月13日 (439)</a><br /> <a class="taga" href="/infotime-20210911-1.html" title="2021年09月11日技术分享文章"> 2021年09月11日 (398)</a><br /> <a class="taga" href="/infotime-20210912-1.html" title="2021年09月12日技术分享文章"> 2021年09月12日 (393)</a><br /> <a class="taga" href="/infotime-20210910-1.html" title="2021年09月10日技术分享文章"> 2021年09月10日 (160)</a><br /> <a class="taga" href="/infotime-20210908-1.html" title="2021年09月08日技术分享文章"> 2021年09月08日 (222)</a><br /> </div> </div> <div class="width100bi margintop20 divborder"> <div class="divtitle"> <div id="infonew1_divtitle" class="divfloatleft divtitlefont">最新文章</div> <div class="divfloatright"> <a href="/info.html" id="infonew1_amore" class="colorCheng" title="最新文章更多>">更多></a></div> <div class="divfloatclear"> </div> </div> <div> <ul> <li class="divullititle heightline25px divtextalignleft"><a href="/infodetail-3830785.html" title=" 6.0 scripts元素 1) 内嵌的 JavaScript 代码 <script type="text/javascript"> document.write("I love FishC.com!") </script> 2) 通过 src 属性引用来自外部代码文件 ..."> 2021/09/28 scripts  <span class="colorlv">2022-05-27</span></a> </li> <li class="divullititle heightline25px divtextalignleft"><a href="/infodetail-3830783.html" title=" 问题场景 后台不提供富文本存储,所以emoji表情入库会报错 需求要求前端在输入的时候过滤掉表情符号 全局的input 和富文本textarea输入框都需要过滤emoji表情 问题分析 1.每一个input写事件写正则校验代码量实在太多了还很麻烦;所以想用自定义全局指令,就不需要每个用到的地方都去引 ..."> vue自定义全局指令v-emoji限制input输入表情和特殊字符  <span class="colorlv">2022-05-27</span></a> </li> <li class="divullititle heightline25px divtextalignleft"><a href="/infodetail-3830781.html" title=" (1)今日计划 四则运算第二阶段 (2)源代码 package size; import java.util.*; import java.lang.Math; public class size { static int count=0; static int ccount=0; static i ..."> 9.26学习总结  <span class="colorlv">2022-05-27</span></a> </li> <li class="divullititle heightline25px divtextalignleft"><a href="/infodetail-3830780.html" title="vim操作 1. 只在指定的特定行中搜索 /pattern\%>27l # 搜索pattern, 搜索范围是27行以后, 其中l表示按行搜索 /pattern\%>27l\%<40l # 搜索pattern, 搜索范围是27行以后40行以前, 其中l表示按行搜索 注意, 不要在%>27l两边随便加空 ..."> vim操作  <span class="colorlv">2022-05-27</span></a> </li> <li class="divullititle heightline25px divtextalignleft"><a href="/infodetail-3830779.html" title=" 说明 主要是学习汇编 windows10 + notepad++ + DOSBox0.74 网上也有notepad++配置自动编译运行的教程,感觉不如手敲命令行原始链接来的快 中断和中断调用 就是调用Dos下的系统接口 中断一览表 MOV AH,09H INT 21H ..."> 深入理解计算机基础 第三章  <span class="colorlv">2022-05-27</span></a> </li> <li class="divullititle heightline25px divtextalignleft"><a href="/infodetail-3830778.html" title="记录一下自己将string作为参数传递的结果。(自己感觉与int等基本类型无异。) 1. string 以引用形式传递 #include <iostream>#include<string> using namespace std;void change_string(string& s){ cha ..."> C++ string 作为形参与引用传递(转)  <span class="colorlv">2022-05-27</span></a> </li> <li class="divullititle heightline25px divtextalignleft"><a href="/infodetail-3830777.html" title=" 常用加解密 1. md5 加密 import hashlib def private_passwd(passwd: str) -> str: return hashlib.md5(passwd.encode(encoding='UTF-8')).hexdigest() 2. base64 加解密 i ..."> python 加解密  <span class="colorlv">2022-05-27</span></a> </li> <li class="divullititle heightline25px divtextalignleft"><a href="/infodetail-3830775.html" title=" let array = [ { id: 1, name: "001", children: [ { id: 2, name: "002", }, ], }, { id: 3, name: "003", children: [] }, ]; function getFlatArr(arr) { ret ..."> JavaScript-对象数组里根据id获取name,对象可能有children属性  <span class="colorlv">2022-05-27</span></a> </li> <li class="divullititle heightline25px divtextalignleft"><a href="/infodetail-3830773.html" title=" SQL语句,追加内容: update 表名 set 字段=CONCAT(字段,'追加的内容') where 字段=? 参考链接:https://www.jb51.net/article/113454.htm ..."> SQL语句——保持现有内容在后面增加内容  <span class="colorlv">2022-05-27</span></a> </li> <li class="divullititle heightline25px divtextalignleft"><a href="/infodetail-3830769.html" title=" virsh [options]... [<command_string>]virsh [options]... <command> [args...] options: -c | --connect=URI hypervisor connection URI -d | --debug=NUM deb ..."> virsh命令文档  <span class="colorlv">2022-05-27</span></a> </li> </ul> </div> </div> <div class="width100bi margintop20 divborder"> <div class="divtitle"> <div id="jctop1_divtitle" class="divfloatleft divtitlefont">教程昨日排行</div> <div class="divfloatright"> <a href="/jiaocheng/" id="jctop1_amore" class="colorCheng">更多></a></div> <div class="divfloatclear"> </div> </div> <div class="divtextalignleft"> <ul> <li class="divullilist"> 1.<a href="/jiaocheng/detail-3742.html" title="list.reverse()" >list.reverse()</a></li> <li class="divullilist"> 2.<a href="/jiaocheng/detail-898.html" title="Django Admin 管理工具" >Django Admin 管理工具</a></li> <li class="divullilist"> 3.<a href="/jiaocheng/detail-1027.html" title="AppML 案例模型" >AppML 案例模型</a></li> <li class="divullilist"> 4.<a href="/jiaocheng/detail-51.html" title="HTML 标签列表(功能排序)" >HTML 标签列表(功能排序)</a></li> <li class="divullilist"> 5.<a href="/jiaocheng/detail-57.html" title="HTML 颜色名" >HTML 颜色名</a></li> <li class="divullilist"> 6.<a href="/jiaocheng/detail-64.html" title="HTML 语言代码" >HTML 语言代码</a></li> <li class="divullilist"> 7.<a href="/jiaocheng/detail-208.html" title="jQuery 事件" >jQuery 事件</a></li> <li class="divullilist"> 8.<a href="/jiaocheng/detail-303.html" title="jEasyUI 创建分割按钮" >jEasyUI 创建分割按钮</a></li> <li class="divullilist"> 9.<a href="/jiaocheng/detail-305.html" title="jEasyUI 创建复杂布局" >jEasyUI 创建复杂布局</a></li> <li class="divullilist"> 10.<a href="/jiaocheng/detail-336.html" title="jEasyUI 创建简单窗口" >jEasyUI 创建简单窗口</a></li> </ul> </div> </div> <script type="text/javascript"> bubuko_load('right_bottom');</script> </div> <div class="divfloatclear"> </div> </div> <script type="text/javascript"> bubuko_load('bottom');</script> <div class="width1000px divmargin0auto paddingtop20bottom20"> <div class="width1000px divborder margintop20"> <div class="youqingtitle"> <a title="友情链接">友情链接</a> </div> <div class="youqingcontent"> <a href='http://www.hubwiz.com/' title='汇智网在线编程学习' target='_blank'>汇智网</a>   <a href='http://www.5ibc.net' title='专注PHP程序员一站式免费学习站点' target='_blank'>PHP教程</a>   <a href='http://www.cnplugins.com/' title='插件网' target='_blank'>插件网</a>   <!--<a href='http://m.bubuko.com/doc3v35e/2022-03-31.html' title='王者荣耀' target='_blank'>王者荣耀</a> <a href='http://m.bubuko.com/doc0tx77/6.html' title='刺激战场' target='_blank'>刺激战场</a> <a href='http://m.bubuko.com/doc27/60.html' title='金铲铲' target='_blank'>金铲铲</a> <a href='http://m.bubuko.com/doc2022-03-31/rolne.html' title='冰封王座' target='_blank'>冰封王座</a> <a href='http://m.bubuko.com/doc20dq0/2022-03-31.html' title='魔兽世界' target='_blank'>魔兽世界</a> <a href='http://m.bubuko.com/docovgq9/2022-03-31.html' title='哔哩哔哩' target='_blank'>哔哩哔哩</a> <a href='http://m.bubuko.com/docuiwrn/27.html' title='狼人杀' target='_blank'>狼人杀</a> <a href='http://m.bubuko.com/doc91/74.html' title='元神' target='_blank'>元神</a> --> </div> </div> </div> <div class="bottomdiv"> <div class="width1000px divmargin0auto paddingtop20"> <div class="divfloatleft width500px"> <div class="height30px"> <a href="/about.html" title="bubuko.com关于我们">关于我们</a> - <a href="/contactus.html" title="bubuko.com联系我们">联系我们</a> - <a href="/guest.html" title="bubuko.com留言反馈">留言反馈</a> - 联系我们:wmxa8@hotmail.com </div> <div class="height30px"> © 2014 <a href="http://www.bubuko.com" title="bubuko.com技术分享">bubuko.com</a> 版权所有 </div> <div> <span class="colorlv">打开技术之扣,分享程序人生!</span> </div> <div class="paddingtop20 paddingbottom20"> <script> var _hmt = _hmt || []; (function() { var hm = document.createElement("script"); hm.src = "https://hm.baidu.com/hm.js?5bb992e19249070395266c385ebea7c6"; var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(hm, s); })(); </script>        <script> (function () { var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })(); </script> </div> </div> <div class="divfloatright width500px"> </div> <div class="divfloatclear"> </div> </div> </div> <script type="text/javascript"> toptopmenu_i = "3"; infomenu_i = "2"; var mid = ''; var id = '3315054'; var idm = '3f6ee3'; var commentitemcount = '0'; var memberhost = ''; prettyPrint(); </script> <script src="/js/infodetail.js" type="text/javascript" charset="utf-8"></script> <script src="/js/member.js" type="text/javascript" charset="utf-8"></script> <script src="/js/bubukojs.js" type="text/javascript"></script> </body> </html>