当前位置:
首页 > temp > JavaScript教程 >
-
JavaScript连载34-addEventListener函数以及闭包的使用
一、addEventListener
<body>
<button id="btn">我是一个按钮</button>
<script>
window.onload = function (ev) {
var btn = document.getElementById("btn");
// btn.onclick = function (ev2) {
// // alert(0);
// window.location.href="http://www.baidu.com";
// }
btn.addEventListener('click',function (ev1) {//添加事件,第一个参数是如何触发第二个参数的事件(函数)
alert(0);
})
}
</script>
</body>
- 可以使用该函数来进行绑定事件,内含有两个参数一个用来指定动作,一个用来指定事件(函数)
二、闭包的运用
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>D34_2_UsageOfClosures</title>
<style>
*{
margin:0;
padding:0;
vertical-align:top;
}
body{
background:url("img/background.jpg") no-repeat;
background-size:cover;
}
#box ul{
display:flex;
justify-content: space-around;
align-items:center;
cursor:pointer;
}
img{
width:250px;
}
li{
list-style: none;
}
</style>
</head>
<body>
<div id="box">
<ul>
<li><img src="img/img_01.png" alt=""></li>
<li><img src="img/img_02.png" alt=""></li>
<li><img src="img/img_03.png" alt=""></li>
<li><img src="img/img_04.png" alt=""></li>
<li><img src="img/img_05.png" alt=""></li>
</ul>
</div>
<script>
window.onload = function (ev) {
//1.获取标签
var box = document.getElementById("box");
var allList = box.getElementsByTagName("li");
//2.遍历监听
for(var i=0;i<allList.length;i++){
//2.1取出单个li标签
var sLi = allList[i];
// sLi.index = i+1;//给予一个属性index
// //2.2监听点击事件
// sLi.addEventListener("click",function (ev2) {
// document.body.style.background ='url("img/img_0' + this.index + '.png") no-repeat';
// });
//也可以使用如下闭包的方式
(function (index) {
sLi.addEventListener("click",function (ev3) {
document.body.style.background ='url("img/img_0' + index + '.png") no-repeat';
});
})(i+1)
}
}
</script>
</body>
</html>
-
还可以使用闭包的方式进行循环输出
三、源码:
- D34_1_SomethingSupplyment.html
- D34_2_UsageOfClosures.html
-
地址:
https://github.com/ruigege66/JavaScript/blob/master/D34_1_SomethingSupplyment.html
-
https://github.com/ruigege66/JavaScript/blob/masterD34_2_UsageOfClosures.html
-
博客园:
https://www.cnblogs.com/ruigege0000/
-
CSDN:
https://blog.csdn.net/weixin_44630050?t=1
出处:https://www.cnblogs.com/ruigege0000/p/13722004.html
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
SQL Server -- 解决存储过程传入参数作为s
关于JS定时器的整理
JS中使用Promise.all控制所有的异步请求都完
js中字符串的方法
import-local执行流程与node模块路径解析流程
检测数据类型的四种方法
js中数组的方法,32种方法
前端操作方法
数据类型
window.localStorage.setItem 和 localStorage.setIte
如何完美解决前端数字计算精度丢失与数