JavaScript-注册事件的两种方式
blur 失去焦点
focus 获得焦点
click 鼠标单击
dblclick 双击
keydown 键盘按下
keyup 键盘弹起
mousedown 鼠标按下
mouseover 鼠标经过
mousemove 鼠标移动
mouseout 鼠标离开
mouseup 鼠标弹起
reset 表单重置
submit 表单提交
change 下拉列表选中项改变,或文本框中内容改变
select 文本被选定
load 页面加载完毕;HTML页面中所有元素全部加载完毕之后才发生
任何一个事件,都会对应一个事件句柄;事件句柄就是在事件前添加on;
onXXX这个事件句柄出现在一个表的属性位置上(事件句柄以属性的形式存在);
回调函数特点:callback函数:自己把这个函数代码写出来,但这个函数不是自己负责调用,由其他程序负责调用该函数
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>js代码执行顺序</title>
<!--
window.onload=function(){}
页面加载的过程中,将函数a注册给了load事件
页面加载完毕之后,load事件发生,此时执行回调函数a
回调函数a执行过程中,把函数b注册给了id="btn"的click事件
-->
</head>
<body>
<script type="text/javascript">
window.onload=function(){//这个回调函数叫做a
document.getElementById("btn").onclick=function(){//回调函数b
alert("hello js");
}
}
</script>
<!--普通按钮-->
<input type="button" value="hello" id="btn"/>
</body>
</html>
<body>
<script type="text/javascript">
//对于当前程序来说,sayHello函数被称为回调函数:callback函数
function sayHello(){
alert("hello js");
}
</script>
<!--以下代码含义:sayHello函数注册到按钮上等click事件之后,该函数被浏览器调用,回调函数-->
<!--注册事件第一种方式,直接在标签中使用事件句柄-->
<input type="button" value ="hello" onclick="sayHello()"/>
<!--第二种注册事件的方式,时使用纯JS代码完成事件的注册-->
<input type="button" value="hello2" id="mybtn"/>
<script type="text/javascript">
document.getElementById("mybtn").onclick=function(){
alert("test4.......");
}
</script>
</body>