ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

JS的事件处理程序

2022-01-25 17:34:06  阅读:175  来源: 互联网

标签:function log JS but2 处理程序 事件 DOM2


一、Html事件处理程序

弊端:与标签耦合度太高,直接绑定在标签体上

	<body>
		<button type="button" onclick="alert('消息框');" onm ouseout="console.log('控制台')">Html事件处理程序</button>
		<button type="button" onclick="fun1();" onm ouseout="console.log('控制台')">Html事件处理程序</button>	
		<script type="text/javascript">
			//Html事件处理程序
			function fun1(){
				alert("消息框");
			}
			
			//加载事件 load   当页面中元素和引入的资源加载完毕之后执行里面的代码
			window.onload = function(){
				//。。。。。。。
			}
		</script>
	</body>

二 、DOM 0级事件处理程序

弊端:不能给同一个元素绑定同一个事件多次

	<body>
		<button type="button" id="but1">DOM0级事件处理程序</button>
		<script type="text/javascript">
			/* DOM0级事件处理程序 */
			//获取元素
			var but1 = document.getElementById("but1");
			// 2.给元素绑定事件
			but1.onclick = function(){
				console.log('DOM0级事件处理程序1');
			}
			//添加的第二的Click事件起作用,第一个被覆盖
			but1.onclick = function(){
				console.log('DOM0级事件处理程序2');
			}
		</script>
	</body>

三、DOM2级事件处理程序

优点:解决了以上的两个弊端,可以绑定对个事件

	<body>
		<button type="button" id="but2">DOM2级事件处理程序</button>
		<button type="button" id="but3">删除DOM2级事件处理程序</button>
		<script type="text/javascript">
			//DOM2级事件处理程序
			//获取元素
			var but2 = document.getElementById("but2");
			var but3 = document.getElementById("but3");
			
			but2.addEventListener("click",function(){
				console.log("DOM2级事件处理程序1");
			});
			but2.addEventListener("click",function(){
				console.log("DOM2级事件处理程序2");
			});
			
			function fun3(){
				console.log("有方法名的处理程序");
			}
			but2.addEventListener('mouseover',fun3);
				
			//移除but2的某个事件
			but3.addEventListener("click",function(){
				but2.removeEventListener('mouseover',fun3);
			});
		</script>
	</body>

标签:function,log,JS,but2,处理程序,事件,DOM2
来源: https://www.cnblogs.com/wml-it/p/15843764.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有