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

View File

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