add: HTML 基础回顾

This commit is contained in:
qianguyihao 2019-10-03 21:36:31 +08:00
parent df5c4b290d
commit 0ea740c0a7
5 changed files with 376 additions and 214 deletions

View File

@ -83,6 +83,13 @@
![](http://img.smyhvae.com/2015-10-01-cnblogs_html_40.png) ![](http://img.smyhvae.com/2015-10-01-cnblogs_html_40.png)
**css 属性**
```css
list-style-position: inside /* 给 ul 设置这个属性后,将小圆点包含在 li 元素的内部 */
```
#### ul标签实际应用场景 #### ul标签实际应用场景
场景1、导航条 场景1、导航条
@ -615,7 +622,7 @@ POST方式
- `password`:密码类型 - `password`:密码类型
- `radio`单选按钮名字相同的按钮作为一组进行单选单选按钮天生是不能互斥的如果想互斥必须要有相同的name属性。name就是“名字”。 - `radio`单选按钮名字相同的按钮作为一组进行单选单选按钮天生是不能互斥的如果想互斥必须要有相同的name属性。name就是“名字”。
。非常像以前的收音机按下去一个按钮其他的就抬起来了。所以叫做radio。 。非常像以前的收音机按下去一个按钮其他的就抬起来了。所以叫做radio。
- `checkbox`:多选按钮,**名字相同的按钮**作为一组进行选择。 - `checkbox`:多选按钮,**name 属性值相同的按钮**作为一组进行选择。
- `checked`:将单选按钮或多选按钮默认处于选中状态。当`<input>`标签的`type="radio"`时可以用这个属性。属性值也是checked可以省略。 - `checked`:将单选按钮或多选按钮默认处于选中状态。当`<input>`标签的`type="radio"`时可以用这个属性。属性值也是checked可以省略。
- `hidden`:隐藏框,在表单中包含不希望用户看见的信息 - `hidden`:隐藏框,在表单中包含不希望用户看见的信息
- `button`普通按钮结合js代码进行使用。 - `button`普通按钮结合js代码进行使用。
@ -637,7 +644,7 @@ POST方式
> 备注HTML5中input的类型又增加了很多比如date、color我们会在 html5 中讲到)。 > 备注HTML5中input的类型又增加了很多比如date、color我们会在 html5 中讲到)。
举例: **举例**
```html ```html
<form> <form>
@ -645,8 +652,8 @@ POST方式
昵称:<input value="哈哈" readonly=""><br> 昵称:<input value="哈哈" readonly=""><br>
名字:<input type="text" value="name" disabled=""><br> 名字:<input type="text" value="name" disabled=""><br>
密码:<input type="password" value="pwd" size="50"><br> 密码:<input type="password" value="pwd" size="50"><br>
性别:<input type="radio" name="gender" value="male" checked=""> 性别:<input type="radio" name="gender" id="radio1" value="male" checked="">
<input type="radio" name="gender" value="female" ><br> <input type="radio" name="gender" id="radio2" value="female" ><br>
爱好:<input type="checkbox" name="love" value="eat">吃饭 爱好:<input type="checkbox" name="love" value="eat">吃饭
<input type="checkbox" name="love" value="sleep">睡觉 <input type="checkbox" name="love" value="sleep">睡觉
<input type="checkbox" name="love" value="bat">打豆豆 <input type="checkbox" name="love" value="bat">打豆豆
@ -657,7 +664,9 @@ POST方式
![](http://img.smyhvae.com/2015-10-02-cnblogs_html_33.png) ![](http://img.smyhvae.com/2015-10-02-cnblogs_html_33.png)
四种按钮的举例: 注意多个个单选框的input标签中name 的属性值可以相同,但是 **id 的属性值必须是唯一的**。我们知道html的标签中id的属性值是唯一的。
**四种按钮的举例**
```html ```html
<form> <form>
@ -812,7 +821,7 @@ text就是“文本”area就是“区域”。
<input type="radio" name="sex" id="nv" /> <label for="nv"></label> <input type="radio" name="sex" id="nv" /> <label for="nv"></label>
``` ```
上方代码中,input元素要有一个id然后label标签有一个for属性和id相同那么这个label和input就有绑定关系了。 上方代码中,让label标签的**for 属性值**,和 input 标签的 **id 属性值相同**那么这个label和input就有绑定关系了。
当然了复选框也有label任何表单元素都有label 当然了复选框也有label任何表单元素都有label

View File

@ -114,7 +114,7 @@ HTML5定义了一系列新元素如新语义标签、智能表单、多媒体
![](http://img.smyhvae.com/20180206_1546.png) ![](http://img.smyhvae.com/20180206_1546.png)
以后我们可以这样写: 在html5中我们可以这样写:
![](http://img.smyhvae.com/20180206_1550.png) ![](http://img.smyhvae.com/20180206_1550.png)
@ -171,28 +171,28 @@ HTML5 则是通过新增语义标签的形式来解决这个问题,例如`<hea
``` ```
## H5中常用的新语义标签 ## H5中新增的语义标签
- `<nav>` 表示导航
- `<header>` 表示页眉
- `<footer>` 表示页脚
- `<section>` 表示区块 - `<section>` 表示区块
- `<article>` 表示文章。如文章、评论、帖子、博客 - `<article>` 表示文章。如文章、评论、帖子、博客
- `<aside>` 表示侧边栏 如文章的侧栏 - `<header>` 表示页眉
- `<footer>` 表示页脚
- `<nav>` 表示导航
- `<aside>` 表示侧边栏。如文章的侧栏
- `<figure>` 表示媒介内容分组。 - `<figure>` 表示媒介内容分组。
- `<mark>` 表示标记 (用得少) - `<mark>` 表示标记 (用得少)
- `<progress>` 表示进度 (用得少) - `<progress>` 表示进度 (用得少)
- `<time>` 表示日期 - `<time>` 表示日期
本质上新语义标签与`<div>`、`<span>`没有区别只是其具有表意性使用时除了在HTML结构上需要注意外其它和普通标签的使用无任何差别可以理解成`<div class="nav">` 相当于`<nav>`。 本质上新语义标签与`<div>`、`<span>`没有区别只是其具有表意性使用时除了在HTML结构上需要注意外其它和普通标签的使用无任何差别可以理解成`<div class="nav">` 相当于`<nav>`。
@ -226,11 +226,11 @@ IE8 及以下版本的浏览器不支持 H5 和 CSS3。解决办法引入`htm
PS:我们在测试 IE 浏览器的兼容的时候,可以使用软件 ietest模拟IE6-IE11。 PS:我们在测试 IE 浏览器的兼容的时候,可以使用软件 ietest模拟IE6-IE11。
在不支持HTML5新标签的浏览器会将这些新的标签解析成行内元素(inline)对待,所以我们只需要将其转换成块元素(block)即可使用。 在不支持HTML5新标签的浏览器会将这些新的标签解析成行内元素(inline)对待,所以我们只需要将其转换成块元素(block)即可使用。
但是在IE9版本以下并不能正常解析这些新标签但是可以识别通过document.createElement('tagName')创建的自定义标签。于是我们的解决方案就是将HTML5的新标签全部通过document.createElement('tagName')来创建一遍这样IE低版本也能正常解析HTML5新标签了。 但是在IE9版本以下并不能正常解析这些新标签但是可以识别通过document.createElement('tagName')创建的自定义标签。于是我们的解决方案就是将HTML5的新标签全部通过document.createElement('tagName')来创建一遍这样IE低版本也能正常解析HTML5新标签了。
当然在实际开发中我们更多采用的办法是检测IE浏览器的版本来加载第三方的JS库来解决兼容问题如上方代码所示 当然在实际开发中我们更多采用的办法是检测IE浏览器的版本来加载第三方的JS库来解决兼容问题如上方代码所示
## H5中的表单 ## H5中的表单
@ -255,9 +255,9 @@ PS:我们在测试 IE 浏览器的兼容的时候,可以使用软件 ietest
- `time` 时间 - `time` 时间
- `date` 日期 - `date` 日期
- `--datetime` 时间日期 - `datetime` 时间日期
- `month` 月份 - `month` 月份
@ -266,7 +266,6 @@ PS:我们在测试 IE 浏览器的兼容的时候,可以使用软件 ietest
上面的部分类型是针对移动设备生效的,且具有一定的兼容性,在实际应用当中可选择性的使用。 上面的部分类型是针对移动设备生效的,且具有一定的兼容性,在实际应用当中可选择性的使用。
代码举例: 代码举例:
```html ```html
@ -354,12 +353,10 @@ PS:我们在测试 IE 浏览器的兼容的时候,可以使用软件 ietest
</html> </html>
``` ```
代码解释: 代码解释:
`<fieldset>` 标签将表单里的内容进行打包,代表一组;而`<legend> `标签的则是 fieldset 里的元素定义标题。 `<fieldset>` 标签将表单里的内容进行打包,代表一组;而`<legend> `标签的则是 fieldset 里的元素定义标题。
### 表单元素(标签) ### 表单元素(标签)
这里讲两个表单元素。 这里讲两个表单元素。
@ -384,7 +381,6 @@ PS:我们在测试 IE 浏览器的兼容的时候,可以使用软件 ietest
上图可以看出,数据列表可以自动提示。 上图可以看出,数据列表可以自动提示。
2、`<keygen>`元素: 2、`<keygen>`元素:
keygen 元素的作用是提供一种验证用户的可靠方法。 keygen 元素的作用是提供一种验证用户的可靠方法。
@ -393,8 +389,6 @@ keygen 元素是密钥对生成器key-pair generator。当提交表单时
私钥private key存储于客户端公钥public key则被发送到服务器。公钥可用于之后验证用户的客户端证书client certificate 私钥private key存储于客户端公钥public key则被发送到服务器。公钥可用于之后验证用户的客户端证书client certificate
3、`<meter>`元素:度量器 3、`<meter>`元素:度量器
- low低于该值后警告 - low低于该值后警告
@ -407,16 +401,12 @@ keygen 元素是密钥对生成器key-pair generator。当提交表单时
- min最小值。 - min最小值。
举例: 举例:
```javascript ```javascript
<meter value="81" min="0" max="100" low="60" high="80"/> <meter value="81" min="0" max="100" low="60" high="80"/>
``` ```
### 表单属性 ### 表单属性
- `placeholder` 占位符(提示文字) - `placeholder` 占位符(提示文字)
@ -435,7 +425,6 @@ keygen 元素是密钥对生成器key-pair generator。当提交表单时
- `pattern` 自定义正则,验证表单。例如 - `pattern` 自定义正则,验证表单。例如
代码举例: 代码举例:
```html ```html
@ -492,7 +481,6 @@ keygen 元素是密钥对生成器key-pair generator。当提交表单时
</html> </html>
``` ```
### 表单事件 ### 表单事件
- `oninput()`:用户输入内容时触发,可用于输入字数统计。 - `oninput()`:用户输入内容时触发,可用于输入字数统计。
@ -563,12 +551,10 @@ keygen 元素是密钥对生成器key-pair generator。当提交表单时
</html> </html>
``` ```
效果: 效果:
![](http://img.smyhvae.com/20180206_1920.gif) ![](http://img.smyhvae.com/20180206_1920.gif)
## 多媒体 ## 多媒体
在HTML5之前在网页上播放音频/视频的通用方法是利用Flash来播放。但是大多情况下并非所有用户的浏览器都安装了Flash插件由此使得音频、视频播放的处理变得非常复杂并且移动设备的浏览器并不支持Flash插件。 在HTML5之前在网页上播放音频/视频的通用方法是利用Flash来播放。但是大多情况下并非所有用户的浏览器都安装了Flash插件由此使得音频、视频播放的处理变得非常复杂并且移动设备的浏览器并不支持Flash插件。
@ -599,7 +585,6 @@ HTML5通过`<audio>`标签来解决音频播放的问题。
- `preload` 预加载 同时设置 autoplay 时,此属性将失效。 - `preload` 预加载 同时设置 autoplay 时,此属性将失效。
**处理兼容性问题:** **处理兼容性问题:**
由于版权等原因,不同的浏览器可支持播放的格式是不一样的: 由于版权等原因,不同的浏览器可支持播放的格式是不一样的:
@ -664,7 +649,6 @@ HTML5通过`<video>`标签来解决视频播放的问题。
</video> </video>
``` ```
## DOM 操作 ## DOM 操作
### 获取元素 ### 获取元素
@ -673,7 +657,6 @@ HTML5通过`<video>`标签来解决视频播放的问题。
- document.querySelectorAll("selector") 通过CSS选择器获取符合条件的所有元素以类数组形式存在。 - document.querySelectorAll("selector") 通过CSS选择器获取符合条件的所有元素以类数组形式存在。
### 类名操作 ### 类名操作
- Node.classList.add("class") 添加class - Node.classList.add("class") 添加class
@ -684,7 +667,6 @@ HTML5通过`<video>`标签来解决视频播放的问题。
- Node.classList.contains("class") 检测是否存在class - Node.classList.contains("class") 检测是否存在class
### 自定义属性 ### 自定义属性
js 里可以通过 `box1.index=100;` `box1.title` 来自定义属性和获取属性。 js 里可以通过 `box1.index=100;` `box1.title` 来自定义属性和获取属性。
@ -726,6 +708,7 @@ H5可以直接在标签里添加自定义属性**但必须以 `data-` 开头*
```html ```html
<!DOCTYPE html> <!DOCTYPE html>
<html lang="en"> <html lang="en">
<head> <head>
<meta charset="UTF-8"> <meta charset="UTF-8">
<title>Tab 标签</title> <title>Tab 标签</title>
@ -777,106 +760,107 @@ H5可以直接在标签里添加自定义属性**但必须以 `data-` 开头*
.cont ol { .cont ol {
line-height: 30px; line-height: 30px;
} }
</style> </style>
</head> </head>
<body> <body>
<div class="tabs"> <div class="tabs">
<nav> <nav>
<a href="javascript:;" data-cont="local">国内新闻</a> <a href="javascript:;" data-cont="local">国内新闻</a>
<a href="javascript:;" data-cont="global">国际新闻</a> <a href="javascript:;" data-cont="global">国际新闻</a>
<a href="javascript:;" data-cont="sports">体育新闻</a> <a href="javascript:;" data-cont="sports">体育新闻</a>
<a href="javascript:;" data-cont="funny">娱乐新闻</a> <a href="javascript:;" data-cont="funny">娱乐新闻</a>
</nav> </nav>
<section class="cont" id="local"> <section class="cont" id="local">
<ol> <ol>
<li>国内新闻1</li> <li>国内新闻1</li>
<li>国内新闻2</li> <li>国内新闻2</li>
<li>国内新闻3</li> <li>国内新闻3</li>
<li>国内新闻4</li> <li>国内新闻4</li>
<li>国内新闻5</li> <li>国内新闻5</li>
<li>国内新闻6</li> <li>国内新闻6</li>
<li>国内新闻7</li> <li>国内新闻7</li>
</ol> </ol>
</section> </section>
<section class="cont" id="global"> <section class="cont" id="global">
<ol> <ol>
<li>国内新闻1</li> <li>国内新闻1</li>
<li>国际新闻2</li> <li>国际新闻2</li>
<li>国际新闻3</li> <li>国际新闻3</li>
<li>国际新闻4</li> <li>国际新闻4</li>
<li>国际新闻5</li> <li>国际新闻5</li>
<li>国际新闻6</li> <li>国际新闻6</li>
</ol> </ol>
</section> </section>
<section class="cont" id="sports"> <section class="cont" id="sports">
<ol> <ol>
<li>体育新闻1</li> <li>体育新闻1</li>
<li>体育新闻2</li> <li>体育新闻2</li>
<li>体育新闻3</li> <li>体育新闻3</li>
<li>体育新闻4</li> <li>体育新闻4</li>
<li>体育新闻5</li> <li>体育新闻5</li>
<li>体育新闻6</li> <li>体育新闻6</li>
<li>体育新闻7</li> <li>体育新闻7</li>
</ol> </ol>
</section> </section>
<section class="cont" id="funny"> <section class="cont" id="funny">
<ol> <ol>
<li>娱乐新闻1</li> <li>娱乐新闻1</li>
<li>娱乐新闻2</li> <li>娱乐新闻2</li>
<li>娱乐新闻3</li> <li>娱乐新闻3</li>
<li>娱乐新闻4</li> <li>娱乐新闻4</li>
<li>娱乐新闻5</li> <li>娱乐新闻5</li>
<li>娱乐新闻6</li> <li>娱乐新闻6</li>
<li>娱乐新闻7</li> <li>娱乐新闻7</li>
</ol> </ol>
</section> </section>
</div> </div>
<script> <script>
// 目标: 默认显示一个 当前的样式 // 目标: 默认显示一个 当前的样式
// 点击导航,实现切换 // 点击导航,实现切换
// key 表示的当前显示的是第几个 // key 表示的当前显示的是第几个
(function (key) { (function (key) {
// 获取所有的导航 // 获取所有的导航
var navs = document.querySelectorAll('nav a'); var navs = document.querySelectorAll('nav a');
// 遍历 给导航 绑定事件,并且添加当前样式 // 遍历 给导航 绑定事件,并且添加当前样式
for (var i = 0; i < navs.length; i++) { for (var i = 0; i < navs.length; i++) {
// 如果是用户指定的当前样式 // 如果是用户指定的当前样式
if (key == i) { if (key == i) {
navs[i].classList.add('active'); navs[i].classList.add('active');
// 拿到要显示内容section的id // 拿到要显示内容section的id
var secId = navs[i].dataset['cont']; var secId = navs[i].dataset['cont'];
// 获取对应的section标签 // 获取对应的section标签
document.querySelector('#' + secId).style.display = 'block'; document.querySelector('#' + secId).style.display = 'block';
}
// 给每一个导航绑定点击事件
navs[i].onclick = function () {
// 排他
// 之前有active样式的清除, 之前显示的section 隐藏
var currentNav = document.querySelector('.active');
// 获取对应的内容区域 ,让其隐藏
var currentId = currentNav.dataset['cont'];
// 去掉导航的active 样式
currentNav.classList.remove('active');
// 对应的内容区域
document.querySelector('#' + currentId).style.display = 'none';
// 突出显示自己 导航添加样式 对应的section 显示
// 给自己添加active样式
this.classList.add('active');
// 对应的section模块显示出来
var myId = this.dataset['cont'];
document.querySelector('#' + myId).style.display = 'block';
}
} }
// 给每一个导航绑定点击事件 })(0);
navs[i].onclick = function () {
// 排他
// 之前有active样式的清除, 之前显示的section 隐藏
var currentNav = document.querySelector('.active');
// 获取对应的内容区域 ,让其隐藏
var currentId = currentNav.dataset['cont'];
// 去掉导航的active 样式
currentNav.classList.remove('active');
// 对应的内容区域
document.querySelector('#' + currentId).style.display = 'none';
// 突出显示自己 导航添加样式 对应的section 显示
// 给自己添加active样式
this.classList.add('active');
// 对应的section模块显示出来
var myId = this.dataset['cont'];
document.querySelector('#' + myId).style.display = 'block';
}
}
})(0);
</script> </script>
</body> </body>
</html> </html>
``` ```

View File

@ -4,15 +4,15 @@
css 进阶的主要内容如下。 css 进阶的主要内容如下。
### 1、html 和 css 基础知识 ### 1、html 和 css 基础知识回顾
- html 元素的分类和特性 - html 元素的分类和特性
- html 元素默认样式和定制化 - html 元素默认样式和定制化
- css 选择器全解析 - css 选择器
- css 常见属性讲解 - css 常见属性
### 2、css 布局相关 ### 2、css 布局相关

View File

@ -0,0 +1,250 @@
## 本文主要内容
- html 的常见元素
- html 元素的分类
- html 元素的嵌套关系
- html 元素的默认样式和定制化
- 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`表单元素。对外的表现是行内元素(不会独占一行),对内的表现是块级元素(可以设置宽高)。
按照内容分类:
20191003_1946.png
图片来源:<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` 仍然是不合法的。
## html 元素的默认样式和定制化
比如下拉框这种比较复杂的元素,是自带默认样式的。如果没有这个默认样式,则该元素在页面上不会有任何表现,则必然增加一些工作量。
同时,默认样式也会带来一些问题:比如,有些默认样式我们是不需要的;有些默认样式甚至无法去掉。
如果我们不需要默认的样式,这里就需要引入一个概念:**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。

View File

@ -1,81 +0,0 @@
## 本文主要内容
- html 常见元素和理解
- html版本
- html 元素分类
- html 元素嵌套关系
- html 元素默认样式和定制化
- 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]