Web/03-CSS进阶/01-HTML基础回顾.md

251 lines
6.3 KiB
Markdown
Raw Normal View History

2019-10-03 21:36:31 +08:00
## 本文主要内容
- html 的常见元素
- html 元素的分类
- html 元素的嵌套关系
2019-10-03 22:49:06 +08:00
- html 元素的默认样式和 CSS Reset
2019-10-03 21:36:31 +08:00
- html 常见面试题
## html 的常见元素
html 的常见元素主要分为两类head 区域的元素、body 区域的元素。下面来分别介绍。
### 1、head 区域的 html 元素
> head 区域的 html 元素,不会在页面上留下直接的内容。
- meta
- title
- style
- link
- script
- base
**base元素的介绍**
```html
<base href="/">
```
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
<section>
<h1>一级标题</h1>
<section>
<h2>二级标题</h2>
<p>段落内容</p>
</section>
<section>
<h2>二级标题</h2>
<p>段落内容</p>
</section>
<aside>
<p>广告内容</p>
</aside>
</section>
<footer>
<p>某某公司出品</p>
</footer>
```
### 查看网页大纲的工具
我们可以通过 <http://h5o.github.io/> 这个工具查看一个网页的大纲。
**使用方法**
1将网址 <http://h5o.github.io/> 保存到书签栏
2去目标网页点击书签栏的网址即可查看该网页的大纲。
这个工具非常好用,既可以查看网页的大纲,也可以查看 markdown 在线文档的结构。
## html 元素的分类
按照样式分类:
- 块级元素
- 行内元素
- inline-block比如`form`表单元素。对外的表现是行内元素(不会独占一行),对内的表现是块级元素(可以设置宽高)。
按照内容分类:
2019-10-03 22:49:06 +08:00
![](http://img.smyhvae.com/20191003_1946.png)
2019-10-03 21:36:31 +08:00
图片来源:<https://html.spec.whatwg.org/multipage/dom.html#kinds-of-content>
## html 元素的嵌套关系
- 块级元素可以包含行内元素。
- 块级元素**不一定**能包含块级元素。比如 div 中可以包含 div但 p 标签中不能包含 div。
- 行内元素**一般**不能包含块级元素。比如 span 中不能包含 div。但有个特例在 HTML5 中, a 标签中可以包含 div。
**注意**:在 HTML5 中 `a > div` 是合法的, `div > a > div`是不合法的 ;但是在 html 4.0.1 中, `a > div` 仍然是不合法的。
2019-10-03 22:49:06 +08:00
## html 元素的默认样式和 CSS Reset
2019-10-03 21:36:31 +08:00
比如下拉框这种比较复杂的元素,是自带默认样式的。如果没有这个默认样式,则该元素在页面上不会有任何表现,则必然增加一些工作量。
同时,默认样式也会带来一些问题:比如,有些默认样式我们是不需要的;有些默认样式甚至无法去掉。
如果我们不需要默认的样式,这里就需要引入一个概念:**CSS Reset**。
### 常见的 CSS Reset 方案
**方案一**
CSS Tools: Reset CSS。链接<https://meyerweb.com/eric/tools/css/reset/>
**方案二**
雅虎的 CSS Reset。链接<https://yuilibrary.com/yui/docs/cssreset/>
我们可以直接通过 CDN 的方式引入:
```html
<link rel="stylesheet" type="text/css" href="http://yui.yahooapis.com/3.18.1/build/cssreset/cssreset-min.css">
```
**方式三**:(比较有争议)
```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也不属于 XMLHTML5有自己独立的一套规范比 XHTML 宽松。
### HTML5 有什么新的变化
- 新的语义化元素
- 表单增强
- 新的API离线、音视频、图形、实时通信、本地存储、设备能力等。
### em 和 i 的区别
共同点:二者都是表示斜体。
区别:
- em 是语义化的标签,表示强调。
- i 是纯样式的标签表示斜体。HTML5 中不推荐使用。
### 语义化的意义是什么
- 开发者容易理解,便于维护。
- 机器(搜索引擎、读屏软件等)容易理解结构
- 有助于 SEO
### 哪些元素可以自闭和
> 自闭和的元素中不能再嵌入别的元素。且 HTML5 中要求加斜杠。
- 表单元素 input
- 图片 img
- br、hr
- meta、link
### form 表单的作用
- 直接提交表单
- 使用 submit / reset 按钮
- 便于浏览器保存表单
- 第三方库(比如 jQuery可以整体获取值
- 第三方库可以进行表单验证
所以,如果我们是通过 Ajax 提交表单数据,也建议加上 form。