JavaScript第七章 事件

JavaScript事件

一、JavaScript中常用事件

  1. blur失去焦点
  2. focus获得焦点
  3. keydown键盘按下
  4. keyup键盘弹起
  5. click鼠标单击
  6. dblclick鼠标双击
  7. mousedown鼠标按下
  8. mouseover鼠标经过
  9. mousemove鼠标移动
  10. mouseout鼠标离开
  11. mouseup鼠标弹起
  12. reset表单重置
  13. submit表单提交
  14. load页面加载完毕(整个HTML页面中所有的元素全部加载完毕之后发生)
  15. select文本被选定
  16. change下拉列表选中项改变,或文本框内容改变
  • 任何一个事件都会对应一个事件句柄,事件句柄是在事件前添加on,事件句柄以属性的形式存在,出现在一个标签的属性位置上

二、事件注册的两种方式

1. 直接在标签中使用事件句柄

<input type="button" value="hello" onclick="lzj()"/>
<script type="text/javascript">
	function lzj(){
		alert("hello lzj");
	}
</script>
// 将lzj函数注册到按钮上,等待click事件发生后,该函数被浏览器调用,对于当前函数来说,称lzj函数为回调函数(callback函数)
  • 回调函数的特点:自己把这个函数代码写出来了,但是这个函数不是自己负责调用,由其他程序负责调用该函数

2. 使用纯JS代码完成事件的注册

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>使用纯JS代码完成事件的注册</title>
		<input type="button" value="hello" id="mybtn" />
		<script type="text/javascript">
			function lzj() {
				alert("Hello LZJ");
			}
			/* 第一步: 先获取这个按钮对象( document全部小写, 内置对象, 可以直接使用, document代表整个HTML页面)​ */
			var obj = document.getElementById("mybtn");
			/* 第二步: 给按钮对象的onclick属性赋值​ */
			// 将回调函数lzj注册到click事件上
			obj.onclick = lzj; // 不能加(),直接用函数名
		</script>
	</head>
	<body>
	</body>
</html>
  • 使用匿名函数完成此方式
<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<input type="button" value="hello" id="mybtn" />
		<!-- <script type="text/javascript">
			function lzj() {
				alert("Hello LZJ");
			}
			/* 第一步: 先获取这个按钮对象( document全部小写, 内置对象, 可以直接使用, document代表整个HTML页面)​ */
			var obj = document.getElementById("mybtn");
			/* 第二步: 给按钮对象的onclick属性赋值​ */
			// 将回调函数lzj注册到click事件上
			obj.onclick = lzj; // 不能加(),直接用函数名
		</script> -->
		<script type="text/javascript">
			var obj = document.getElementById("mybtn");
			// 使用匿名函数,这个匿名函数也是回调函数
			obj.onclick = function() {
				alert("Hello LZJ");
			}
			// 简写
			/* document.getElementById("mybtn").onclick = function(){
				alert("Hello LZJ");
			} */
		</script>
	</head>
	<body>
	</body>
</html>

三、JS代码的执行顺序

不写onload,input标签放在后则不能执行,因为页面还没有加载到id
<script type="text/javascript">
	// 页面打开,function就注册成功
	// 页面加载的过程中,将第一个function函数注册给load事件
	window.onload = function(){
	// 页面加载完毕,将第二个function函数注册成功
	// 页面加载完毕,load事件发生,此时执行回调函数(第一个function)
	// 回调函数(第一个function)执行过程中,把第二个function函数注册给了id="mybtn"的click事件
	// 当id="mybtn"发生click事件之后,第二个function函数被调用执行
		document.getElementById("mybtn").onclick = function(){
			alert("hello lzj");
		}
	}
</script>
<input type="button" value="hello" id="mybtn"/>

四、JS代码捕捉键值

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<script type="text/javascript">
			window.onload = function() {
				var m = document.getElementById("lzj");
				m.onkeydown = function(event) { // 获取键值(回车键13,ESC键27)
					// 对于“键盘事件对象”来说,都有keyCode属性用来获取键值
					alert(event.keyCode);
				}
			}
			// 回车验证
			m.onkeydown = function() {
				if (event.keyCode === 13) {
					alert("正在验证......");
				}
			}
		</script>
	</head>
	<body>
		<input type="text" id="lzj" />
	</body>
</html>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Jayco江柯

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值