Web/04-JavaScript基础/39-事件简介.md

329 lines
9.5 KiB
JavaScript
Raw Normal View History

2019-08-04 17:41:02 +08:00
> 本文最初发表于[博客园](http://www.cnblogs.com/smyhvae/p/8366012.html),并在[GitHub](https://github.com/qianguyihao/Web)上持续更新**前端的系列文章**。欢迎在GitHub上关注我一起入门和进阶前端。
> 以下是正文
## 事件简介
事件就是文档或浏览器窗口中发生的一些特定的交互瞬间对于 Web 应用来说有下面这些代表性的事件点击某个元素将鼠标移动至某个元素上方关闭弹窗等等
JavaScript 是以**事件驱动为核心**的一门语言JavaScript HTML 之间的交互是通过事件实现的
### 事件的三要素
**事件的三要素事件源事件事件驱动程序**
比如我用手去按开关灯亮了这件事情里事件源是事件是按开关事件驱动程序是灯开了或者关了
再比如网页上弹出一个广告我点击右上角的`X`广告就关闭了这件事情里事件源是`X`事件是onclick事件驱动程序是广告关闭了
于是我们可以总结出谁引发的后续事件谁就是事件源
**总结如下**
- 事件源引发后续事件的html标签
- 事件js已经定义好了见下图
- 事件驱动程序对样式和html的操作也就是DOM
也就是说我们可以在时间对应的属性中写一些js代码当事件被触发时这些代码将会执行
**代码书写步骤如下**重要
- 1获取事件源document.getElementById(box); // 类似于Android里面的findViewById
- 2绑定事件 事件源box.事件onclick = function(){ 事件驱动程序 };
- 3书写事件驱动程序关于DOM的操作
最简单的代码举例点击box1然后弹框
```html
<body>
<div id="box1"></div>
<script type="text/javascript">
// 1、获取事件源
var div = document.getElementById("box1");
// 2、绑定事件
div.onclick = function () {
// 3、书写事件驱动程序
alert("我是弹出的内容");
}
</script>
</body>
```
常见的事件如下
![](http://img.smyhvae.com/20180126_1553.png)
下面针对这事件的三要素进行分别介绍
### 1获取事件源的方式DOM节点的获取
获取事件源的常见方式如下
```javascript
2019-08-04 20:00:53 +08:00
var div1 = document.getElementById("box1"); //方式一通过id获取单个标签
2019-08-04 17:41:02 +08:00
2019-08-04 20:00:53 +08:00
var arr1 = document.getElementsByTagName("div"); //方式二:通过 标签名 获得 标签数组所以有s
2019-08-04 17:41:02 +08:00
2019-08-04 20:00:53 +08:00
var arr2 = document.getElementsByClassName("hehe"); //方式三:通过 类名 获得 标签数组所以有s
2019-08-04 17:41:02 +08:00
```
### 2绑定事件的方式
方式一直接绑定匿名函数
```html
<div id="box1" ></div>
<script type="text/javascript">
var div1 = document.getElementById("box1");
//绑定事件的第一种方式
div1.onclick = function () {
alert("我是弹出的内容");
}
</script>
```
方式二先单独定义函数再绑定
```html
<div id="box1" ></div>
<script type="text/javascript">
var div1 = document.getElementById("box1");
//绑定事件的第二种方式
div1.onclick = fn; //注意这里是fn不是fn()。fn()指的是返回值。
//单独定义函数
function fn() {
alert("我是弹出的内容");
}
</script>
```
注意上方代码的注释**绑定的时候是写fn不是写fn()**fn代表的是整个函数而fn()代表的是返回值
方式三行内绑定
```html
<!--行内绑定-->
<div id="box1" onclick="fn()"></div>
<script type="text/javascript">
function fn() {
alert("我是弹出的内容");
}
</script>
```
注意第一行代码绑定时是写的`"fn()"`不是写的`"fn"`因为绑定的这段代码不是写在js代码里的而是被识别成了**字符串**
### 3事件驱动程序
我们在上面是拿alert举例不仅如此我们还可以操作标签的属性和样式举例如下
点击鼠标时原本粉色的div变大了背景变红
```html
<style>
#box1 {
width: 100px;
height: 100px;
background-color: pink;
cursor: pointer;
}
</style>
</head>
<body>
<div id="box1" ></div>
<script type="text/javascript">
var div1 = document.getElementById("box1");
//点击鼠标时原本粉色的div变大了背景变红了
div1.onclick = function () {
div1.style.width = "200px"; //属性值要写引号
div1.style.height = "200px";
div1.style.backgroundColor = "red"; //属性名是backgroundColor不是background-color
}
</script>
```
上方代码的注意事项
- 在js里写属性值时要用引号
- 在js里写属性名时`backgroundColor`不是CSS里面的`background-color`
实现效果如下
![](http://img.smyhvae.com/20180126_1720.gif)
### onload事件
> onload事件比较特殊这里单独讲一下
**当页面加载文本和图片完毕的时候触发onload事件**
举例
```html
<script type="text/javascript">
window.onload = function () {
console.log("smyhvae"); //等页面加载完毕时,打印字符串
}
</script>
```
有一点我们要知道**js的加载是和html同步加载的**因此如果使用元素在定义元素之前容易报错这个时候onload事件就能派上用场了我们可以把使用元素的代码放在onload里就能保证这段代码是最后执行
2019-09-03 10:09:04 +08:00
建议是整个页面上所有元素加载完毕再执行js内容所以window.onload可以预防使用标签在定义标签之前
**备注**关于 onLoad事件在下一篇文章24-DOM简介和DOM操作中有更详细的讲解和示例
2019-08-04 17:41:02 +08:00
### 事件举例京东顶部广告栏
![](http://img.smyhvae.com/20180122_1020.png)
比如上面这张图当鼠标点击右上角的`X`关掉整个广告栏这就要用到事件
代码实现如下
```html
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<style>
* {
padding: 0;
margin: 0;
}
.top-banner {
background-color: pink;
height: 80px;
}
.w {
width: 1210px;
margin: 10px auto;
position: relative;
}
img {
display: block;
width: 1210px;
height: 80px;
background-color: blue;
}
a {
position: absolute;
top: 5px;
right: 5px;
color: #fff;
background-color: #000;
text-decoration: none;
width: 20px;
height: 20px;
font: 700 14px/20px "simsum";
text-align: center;
}
.hide {
display: none!important;
}
</style>
</head>
<body>
<div class="top-banner" id="topBanner">
<div class="w">
<img src="" alt=""/>
<a href="#" id="closeBanner">×</a>
</div>
</div>
<script>
//需求:点击案例,隐藏盒子。
//思路点击a链接让top-banner这个盒子隐藏起来加隐藏类名
//1.获取事件源和相关元素
var closeBanner = document.getElementById("closeBanner");
var topBanner = document.getElementById("topBanner");
//2.绑定事件
closeBanner.onclick = function () {
//3.书写事件驱动程序
//类控制
// topBanner.className += " hide"; //保留原类名,添加新类名
topBanner.className = "hide";//替换旧类名(方式一)
// topBanner.style.display = "none"; //方式二:与上一行代码的效果相同
}
</script>
</body>
</html>
```
注意最后一行代码这种方式会替换旧类名意思是不管之前的类名叫什么都会被修改
### 事件举例
要求实现效果当鼠标悬停在img上时更换为另外一张图片鼠标离开时还原为本来的图片
代码实现
```html
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title></title>
<script>
//window.onload页面加载完毕以后再执行此代码
window.onload = function () {
//需求鼠标放到img上更换为另一张图片也就是修改路径src的值
//步骤:
//1.获取事件源
//2.绑定事件
//3.书写事件驱动程序
//1.获取事件源
var img = document.getElementById("box");
//2.绑定事件(悬停事件:鼠标进入到事件源中,立即触发事件)
img.onmouseover = function () {
//3.书写事件驱动程序(修改src)
img.src = "image/jd2.png";
// this.src = "image/jd2.png";
}
//2.绑定事件(悬停事件:鼠标进入到事件源中,立即触发事件)
img.onmouseout = function () {
//3.书写事件驱动程序(修改src)
img.src = "image/jd1.png";
}
}
</script>
</head>
<body>
<img id="box" src="image/jd1.png" style="cursor: pointer;border: 1px solid #ccc;"/>
</html>
```
## 我的公众号
想学习**代码之外的技能**不妨关注我的微信公众号**千古壹号**id`qianguyihao`
扫一扫你将发现另一个全新的世界而这将是一场美丽的意外
![](http://img.smyhvae.com/20190101.png)