JavaScript 为元素绑定和解绑事件

2024-01-08 19:32

本文主要是介绍JavaScript 为元素绑定和解绑事件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

为元素绑定事件:

1、对象.带on的事件类型 = 事件处理函数;    只能绑定一个事件处理函数,后面的会覆盖前面的。

2、对象.addEventListener("没有on的事件类型", 事件处理函数, false); ————谷歌、火狐、IE11支持,IE8不支持

       可以绑定多个事件处理函数。

3、对象.attachEvent("带on的事件类型", 事件处理函数); ————谷歌、火狐、IE11不支持,IE8支持

       可以绑定多个事件处理函数。

事件处理函数————是函数,可以是命名函数,也可以是匿名函数,但是在有对应的解绑事件的时候要用命名函数。

为同一个元素绑定多个相同的事件

addEventListener
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<input type="button" value="按钮" id="btn"/>
<script>var btn = document.getElementById("btn");btn.addEventListener("click", function(){console.log("我是addEventListener事件一");}, false);btn.addEventListener("click", function(){console.log("我是addEventListener事件二");}, false);btn.addEventListener("click", function(){console.log("我是addEventListener事件三");}, false);btn.addEventListener("click", function(){console.log("我是addEventListener事件四");}, false);
</script>
</body>
</html>

attachEvent

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<input type="button" value="按钮" id="btn"/>
<script>var btn = document.getElementById("btn");btn.attachEvent("onclick", function(){console.log("我是attachEvent事件一");});btn.attachEvent("onclick", function(){console.log("我是attachEvent事件二");});btn.attachEvent("onclick", function(){console.log("我是attachEvent事件三");});btn.attachEvent("onclick", function(){console.log("我是attachEvent事件四");});
</script>
</body>
</html>

addEventListener() 和 attachEvent() 的总结:

相同点:都可以为元素绑定事件

不同点:

1、方法名字不一样。

2、参数个数不一样,addEventListener有三个参数,attachEvent有两个参数。

3、addEventListener参数中的事件类型(事件的名字)没有on,attachEvent参数中的事件类型(事件的名字)有on。

4、addEventListener 谷歌、火狐、IE11支持,IE8不支持,attachEvent 谷歌、火狐、IE11不支持,IE8支持。

5、this不同,addEventListener 中的this是当前绑定事件的对象,但attachEvent 中的this是window。

为元素解绑事件:

要注意,用什么方法绑定的事件,就用什么方法解绑。

方法一:通过DOM元素的onclick等事件属性,为元素绑定事件。

绑定事件:对象.on事件名字=事件处理函数

解绑事件:对象.on事件名字=null;

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<button id="btn1">绑定事件</button>
<button id="btn2">解绑事件</button>
<script>var btn1 = document.getElementById("btn1");var btn2 = document.getElementById("btn2");//绑定事件btn1.onclick = function(){console.log("绑定了onclick事件");};btn2.onclick = function(){//解绑事件btn1.onclick = null;};
</script>
</body>
</html>

方法二:addEventListener  和  removeEventListener

绑定事件:对象.addEventListener("没有on的事件类型", 命名函数, false);

解绑事件:对象.removeEventListener("没有on的事件类型", 函数名字, false);

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<button id="btn1">绑定事件</button>
<button id="btn2">解绑事件</button>
<script>var btn1 = document.getElementById("btn1");var btn2 = document.getElementById("btn2");function f1(){console.log("事件一");}function f2(){console.log("事件二");}function f3(){console.log("事件三");}//绑定事件btn1.addEventListener("click", f1, false);btn1.addEventListener("click", f2, false);btn1.addEventListener("click", f3, false);//点击第二个按钮,解绑事件btn2.onclick = function(){//有解绑事件的,需要在绑定事件的时候使用命名函数btn1.removeEventListener("click", f2, false);};
</script>
</body>
</html>

方法三:attachEvent 和 detachEvent

绑定事件:对象.attachEvent("on事件类型", 命名函数 );

解绑事件:对象.detachEvent("on事件类型", 函数名字);

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<button id="btn1">绑定事件</button>
<button id="btn2">解绑事件</button>
<script>var btn1 = document.getElementById("btn1");var btn2 = document.getElementById("btn2");function f1(){console.log("事件一");}function f2(){console.log("事件二");}function f3(){console.log("事件三");}//绑定事件btn1.attachEvent("onclick", f1);btn1.attachEvent("onclick", f2);btn1.attachEvent("onclick", f3);//点击第二个按钮,解绑事件btn2.onclick = function(){//有解绑事件的,需要在绑定事件的时候使用命名函数btn1.detachEvent("onclick", f2);};
</script>
</body>
</html>

兼容代码

绑定事件:为任意元素绑定任意事件

    //为任意元素绑定任意事件,参数:元素,不带on的事件类型,事件处理函数function addEvent(element, type, fn){if(element.addEventListener){element.addEventListener(type, fn, false);}else if(element.attachEvent){element.attachEvent("on"+type, fn);}else{element["on"+type] = fn;}}

解绑事件

    //为任意元素解绑任意事件,参数:元素,不带on的事件类型,事件处理函数名字function removeEvent(element, type, fnName){if(element.removeEventListener){element.removeEventListener(type, fnName, false);}else if(element.detachEvent){element.detachEvent("on"+type, fnName);}else{element["on"+type] = null;}}

案例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Title</title>
</head>
<body>
<button id="btn1">绑定事件</button>
<button id="btn2">解绑事件</button>
<script>var btn1 = document.getElementById("btn1");var btn2 = document.getElementById("btn2");function f1(){console.log("事件一");}function f2(){console.log("事件二");}function f3(){console.log("事件三");}//绑定事件addEvent(btn1, "click", f1);addEvent(btn1, "click", f2);addEvent(btn1, "click", f3);//点击第二个按钮,解绑事件btn2.onclick = function(){//有解绑事件的,需要在绑定事件的时候使用命名函数removeEvent(btn1, "click", f2);};//为任意元素绑定任意事件,参数:元素,不带on的事件类型,事件处理函数function addEvent(element, type, fn){if(element.addEventListener){element.addEventListener(type, fn, false);}else if(element.attachEvent){element.attachEvent("on"+type, fn);}else{element["on"+type] = fn;}}//为任意元素解绑任意事件,参数:元素,不带on的事件类型,事件处理函数名字function removeEvent(element, type, fnName){if(element.removeEventListener){element.removeEventListener(type, fnName, false);}else if(element.detachEvent){element.detachEvent("on"+type, fnName);}else{element["on"+type] = null;}}
</script>
</body>
</html>
任何浏览器都支持该兼容代码。

这篇关于JavaScript 为元素绑定和解绑事件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/584564

相关文章

Java实现删除文件中的指定内容

《Java实现删除文件中的指定内容》在日常开发中,经常需要对文本文件进行批量处理,其中,删除文件中指定内容是最常见的需求之一,下面我们就来看看如何使用java实现删除文件中的指定内容吧... 目录1. 项目背景详细介绍2. 项目需求详细介绍2.1 功能需求2.2 非功能需求3. 相关技术详细介绍3.1 Ja

springboot项目中整合高德地图的实践

《springboot项目中整合高德地图的实践》:本文主要介绍springboot项目中整合高德地图的实践,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一:高德开放平台的使用二:创建数据库(我是用的是mysql)三:Springboot所需的依赖(根据你的需求再

spring中的ImportSelector接口示例详解

《spring中的ImportSelector接口示例详解》Spring的ImportSelector接口用于动态选择配置类,实现条件化和模块化配置,关键方法selectImports根据注解信息返回... 目录一、核心作用二、关键方法三、扩展功能四、使用示例五、工作原理六、应用场景七、自定义实现Impor

SpringBoot3应用中集成和使用Spring Retry的实践记录

《SpringBoot3应用中集成和使用SpringRetry的实践记录》SpringRetry为SpringBoot3提供重试机制,支持注解和编程式两种方式,可配置重试策略与监听器,适用于临时性故... 目录1. 简介2. 环境准备3. 使用方式3.1 注解方式 基础使用自定义重试策略失败恢复机制注意事项

SpringBoot整合Flowable实现工作流的详细流程

《SpringBoot整合Flowable实现工作流的详细流程》Flowable是一个使用Java编写的轻量级业务流程引擎,Flowable流程引擎可用于部署BPMN2.0流程定义,创建这些流程定义的... 目录1、流程引擎介绍2、创建项目3、画流程图4、开发接口4.1 Java 类梳理4.2 查看流程图4

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热

Java对异常的认识与异常的处理小结

《Java对异常的认识与异常的处理小结》Java程序在运行时可能出现的错误或非正常情况称为异常,下面给大家介绍Java对异常的认识与异常的处理,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参... 目录一、认识异常与异常类型。二、异常的处理三、总结 一、认识异常与异常类型。(1)简单定义-什么是

SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志

《SpringBoot项目配置logback-spring.xml屏蔽特定路径的日志》在SpringBoot项目中,使用logback-spring.xml配置屏蔽特定路径的日志有两种常用方式,文中的... 目录方案一:基础配置(直接关闭目标路径日志)方案二:结合 Spring Profile 按环境屏蔽关

Java使用HttpClient实现图片下载与本地保存功能

《Java使用HttpClient实现图片下载与本地保存功能》在当今数字化时代,网络资源的获取与处理已成为软件开发中的常见需求,其中,图片作为网络上最常见的资源之一,其下载与保存功能在许多应用场景中都... 目录引言一、Apache HttpClient简介二、技术栈与环境准备三、实现图片下载与保存功能1.

SpringBoot排查和解决JSON解析错误(400 Bad Request)的方法

《SpringBoot排查和解决JSON解析错误(400BadRequest)的方法》在开发SpringBootRESTfulAPI时,客户端与服务端的数据交互通常使用JSON格式,然而,JSON... 目录问题背景1. 问题描述2. 错误分析解决方案1. 手动重新输入jsON2. 使用工具清理JSON3.