页面对不同访问者的响应叫做事件。
事件处理程序指的是当 HTML 中发生某些事件时所调用的方法。
实例:
在事件中经常使用术语"触发"(或"激发")例如: "当您按下按键时触发 keypress 事件"。
常见 DOM 事件:
鼠标事件 | 键盘事件 | 表单事件 | 文档/窗口事件 |
---|---|---|---|
click | keypress | submit | load |
dblclick | keydown | change | resize |
mouseenter | keyup | focus | scroll |
mouseleave | blur | unload |
在 jQuery 中,大多数 DOM 事件都有一个等效的 jQuery 方法。
页面中指定一个点击事件:
$("p").click(); |
$("p").click(function(){ |
// 动作触发后执行的代码!! |
}); |
$(document).ready()
$(document).ready() 方法允许我们在文档完全加载完后执行函数。该事件方法在 jQuery 语法 章节中已经提到过。
click()
click() 方法是当按钮点击事件被触发时会调用一个函数。
该函数在用户点击 HTML 元素时执行。
在下面的实例中,当点击事件在某个 <p> 元素上触发时,隐藏当前的 <p> 元素:
<!DOCTYPE html> |
<html> |
<head> |
<meta charset="utf-8"> |
<title>芝麻教程(web3.xin)</title> |
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"> |
</script> |
<script> |
$(document).ready(function(){ |
$("p").click(function(){ |
$(this).hide(); |
}); |
}); |
</script> |
</head> |
<body> |
<p>如果你点我,我就会消失。</p> |
<p>点我消失!</p> |
<p>点我也消失!</p> |
</body> |
</html> |
dblclick()
当双击元素时,会发生 dblclick 事件。
dblclick() 方法触发 dblclick 事件,或规定当发生 dblclick 事件时运行的函数:
<!DOCTYPE html> |
<html> |
<head> |
<meta charset="utf-8"> |
<title>芝麻教程(web3.xin)</title> |
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"> |
</script> |
<script> |
$(document).ready(function(){ |
$("p").dblclick(function(){ |
$(this).hide(); |
}); |
}); |
</script> |
</head> |
<body> |
<p>双击鼠标左键的,我就消失。</p> |
<p>双击我消失!</p> |
<p>双击我也消失!</p> |
</body> |
</html> |
mouseenter()
当鼠标指针穿过元素时,会发生 mouseenter 事件。
mouseenter() 方法触发 mouseenter 事件,或规定当发生 mouseenter 事件时运行的函数:
<!DOCTYPE html> |
<html> |
<head> |
<meta charset="utf-8"> |
<title>芝麻教程(web3.xin)</title> |
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"> |
</script> |
<script> |
$(document).ready(function(){ |
$("#p1").mouseenter(function(){ |
alert("您的鼠标移到了 id=p1 的元素上!"); |
}); |
}); |
</script> |
</head> |
<body> |
<p id="p1">鼠标指针进入此处,会看到弹窗。</p> |
</body> |
</html> |
mouseleave()
当鼠标指针离开元素时,会发生 mouseleave 事件。
mouseleave() 方法触发 mouseleave 事件,或规定当发生 mouseleave 事件时运行的函数:
<!DOCTYPE html> |
<html> |
<head> |
<meta charset="utf-8"> |
<title>芝麻教程(web3.xin)</title> |
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"> |
</script> |
<script> |
$(document).ready(function(){ |
$("#p1").mouseleave(function(){ |
alert("再见,您的鼠标离开了该段落。"); |
}); |
}); |
</script> |
</head> |
<body> |
<p id="p1">这是一个段落。</p> |
</body> |
</html> |
mousedown()
当鼠标指针移动到元素上方,并按下鼠标按键时,会发生 mousedown 事件。
mousedown() 方法触发 mousedown 事件,或规定当发生 mousedown 事件时运行的函数:
<!DOCTYPE html> |
<html> |
<head> |
<meta charset="utf-8"> |
<title>芝麻教程(web3.xin)</title> |
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"> |
</script> |
<script> |
$(document).ready(function(){ |
$("#p1").mousedown(function(){ |
alert("鼠标在该段落上按下!"); |
}); |
}); |
</script> |
</head> |
<body> |
<p id="p1">这是一个段落</p> |
</body> |
</html> |
hover()
hover()方法用于模拟光标悬停事件。
当鼠标移动到元素上时,会触发指定的第一个函数(mouseenter);当鼠标移出这个元素时,会触发指定的第二个函数(mouseleave)。
$("#p1").hover(function(){ |
alert("You entered p1!"); |
}, |
function(){ |
alert("Bye! You now leave p1!"); |
}); |
focus()
当元素获得焦点时,发生 focus 事件。
当通过鼠标点击选中元素或通过 tab 键定位到元素时,该元素就会获得焦点。
focus() 方法触发 focus 事件,或规定当发生 focus 事件时运行的函数:
$("input").focus(function(){ |
$(this).css("background-color","#cccccc"); |
}); |
blur()
当元素失去焦点时,发生 blur 事件。
blur() 方法触发 blur 事件,或规定当发生 blur 事件时运行的函数:
$("input").blur(function(){ |
$(this).css("background-color","#ffffff"); |
}); |