--- title: 12-HTML基础回顾 publish: true --- ## 本文主要内容 - html 的常见元素 - html 元素的分类 - html 元素的嵌套关系 - html 元素的默认样式和 CSS Reset - html 常见面试题 ## html 的常见元素 html 的常见元素主要分为两类:head 区域的元素、body 区域的元素。下面来分别介绍。 ### 1、head 区域的 html 元素 > head 区域的 html 元素,不会在页面上留下直接的内容。 - meta - title - style - link - script - base **base元素的介绍**: ```html ``` base 标签用于指定基础的路径。指定之后,所有的 a 链接都是以这个路径为基准。 ### 2、html 元素(body 区域) > body 区域的 html 元素,会直接出现在页面上。 - div、section、article、aside、header、footer - p - span、em、strong - 表格元素:table、thead、tbody、tr、td - 列表元素:ul、ol、dl、dt、dd - a - 表单元素:form、input、select、textarea、button div 是最常见的元素,大多数场景下,都可以用div(实在不行就多包几层div)。可见,**div 是比较通用的元素,这也决定了 div 的的语义并不是很明确**。 **常见标签的重要属性**: - a[href,target] - img[src,alt] - table td[colspan,rowspan]。设置当前单元格占据几行几列。在合并单元格时,会用到。 - form[target,method,enctype] - input[type,value] - button[type] - selection>option[value] - label[for] ### html 文档的大纲 我们平时在写论文或者其他文档的时候,一般会先列出大纲,然后再写具体的内容。 同样,html 网页也可以看成是一种文档,也有属于它的大纲。 一个常见的html文档,它的结构可以是: ```html

一级标题

二级标题

段落内容

二级标题

段落内容

``` ### 查看网页大纲的工具 我们可以通过 这个工具查看一个网页的大纲。 **使用方法**: (1)将网址 保存到书签栏 (2)去目标网页,点击书签栏的网址,即可查看该网页的大纲。 这个工具非常好用,既可以查看网页的大纲,也可以查看 markdown 在线文档的结构。 ## html 元素的分类 按照样式分类: - 块级元素 - 行内元素 - inline-block:比如`form`表单元素。对外的表现是行内元素(不会独占一行),对内的表现是块级元素(可以设置宽高)。 按照内容分类: ![](http://img.smyhvae.com/20191003_1946.png) 图片来源: ## html 元素的嵌套关系 - 块级元素可以包含行内元素。 - 块级元素**不一定**能包含块级元素。比如 div 中可以包含 div,但 p 标签中不能包含 div。 - 行内元素**一般**不能包含块级元素。比如 span 中不能包含 div。但有个特例:在 HTML5 中, a 标签中可以包含 div。 **注意**:在 HTML5 中 `a > div` 是合法的, `div > a > div`是不合法的 ;但是在 html 4.0.1 中, `a > div` 仍然是不合法的。 ## html 元素的默认样式和 CSS Reset 比如下拉框这种比较复杂的元素,是自带默认样式的。如果没有这个默认样式,则该元素在页面上不会有任何表现,则必然增加一些工作量。 同时,默认样式也会带来一些问题:比如,有些默认样式我们是不需要的;有些默认样式甚至无法去掉。 如果我们不需要默认的样式,这里就需要引入一个概念:**CSS Reset**。 ### 常见的 CSS Reset 方案 **方案一**: CSS Tools: Reset CSS。链接: **方案二**: 雅虎的 CSS Reset。链接: 我们可以直接通过 CDN 的方式引入: ```html ``` **方式三**:(比较有争议) ```css *{ margin: 0; padding: 0; } ``` 上面何种写法,比较简洁,但也有争议。有争议的地方在于,可能会导致 css 选择器的性能问题。 ### Normalize.css 上面的几种 css reset 的解决思路是:将所有的默认样式清零。 但是,[Normalize.css](https://necolas.github.io/normalize.css/) 的思路是:既然浏览器提供了这些默认样式,那它就是有意义的。**既然不同浏览器的默认样式不一致,那么,`Normalize.css`就将这些默认样式设置为一致**。 ## html 常见面试题 ### doctype 的意义是什么 - 让浏览器以标准模式渲染 - 让浏览器知道元素的合法性 ### HTML、XHTML、HTML5的区别 - HTML 属于 SGML - XHTML 属于 XML,是 HTML 进行 XML 严格化的结果 - HTML5 不属于SGML,也不属于 XML(HTML5有自己独立的一套规范),比 XHTML 宽松。 ### HTML5 有什么新的变化 - 新的语义化元素 - 表单增强 - 新的API:离线、音视频、图形、实时通信、本地存储、设备能力等。 ### em 和 i 的区别 共同点:二者都是表示斜体。 区别: - em 是语义化的标签,表示强调。 - i 是纯样式的标签,表示斜体。HTML5 中不推荐使用。 ### 语义化的意义是什么 - 开发者容易理解,便于维护。 - 机器(搜索引擎、读屏软件等)容易理解结构 - 有助于 SEO ### 哪些元素可以自闭合 > 自闭合的元素中不能再嵌入别的元素。且 HTML5 中要求加斜杠。 - 表单元素 input - 图片 img - br、hr - meta、link ### form 表单的作用 - 直接提交表单 - 使用 submit / reset 按钮 - 便于浏览器保存表单 - 第三方库(比如 jQuery)可以整体获取值 - 第三方库可以进行表单验证 所以,如果我们是通过 Ajax 提交表单数据,也建议加上 form。