3.10JQuery事件操作
$( function(){} )和 window.onload = function(){} 的区别?
1、 触发的时间:
(1) jQuery 的页面加载完成之后是浏览器的内核解析完页面的标签创建好 DOM 对象之后就会马上执行;
(2) 原生 js 的页面加载完成之后,除了要等浏览器内核解析完标签创建好 DOM 对象,还要等标签显示时需要的内容加载完成
(总结:也就是原生的比JQuery的慢)。
2、 触发的顺序:
(1) jQuery 页面加载完成之后先执行;
(2) 原生 js 的页面加载完成之后。
3、 执行的次数:
(1) 原生 js 的页面加载完成之后,只会执行最后一次的赋值函数;
(2) jQuery 的页面加载完成之后是全部把注册的 function 函数,依次顺序全部执行。
jQuery 中其他的事件处理方法:
1、 click() 它可以绑定单击事件,以及触发单击事件;
2、 mouseover() 鼠标移入事件;
3、 mouseout() 鼠标移出事件;
4、 bind() 可以给元素一次性绑定一个或多个事件;
5、 one() 使用上跟 bind 一样。但是 one 方法绑定的事件只会响应一次;
6、 unbind() 跟 bind 方法相反的操作,解除事件的绑定;
7、 live() 也是用来绑定事件。它可以用来绑定选择器匹配的所有元素的事件。哪怕这个元素是后面动态创建出来的也有效。
事件的冒泡
事件的冒泡是指,父子元素同时监听同一个事件。当触发子元素的事件的时候,同一个事件也被传递到了父元素的事件里去响应。(比如说:父元素绑定了单击响应函数,子元素也绑定了单击响应函数,如果触发了子元素的单击绑定事件,那么父元素的单击响应事件也会触发)。在子元素事件函数体内,return false; 可以阻止事件的冒泡传递。
javaScript 事件对象
事件对象,是封装有触发的事件信息的一个 javascript 对象。在给元素绑定事件的时候,在事件的 function( event ) 参数列表中添加一个参数,这个参数名,我们习惯取名为 event。 这个 event 就是 javascript 传递参事件处理函数的事件对象。
如:使用 bind 同时对多个事件绑定同一个函数,获取当前操作是什么事件。
1. $("#areaDiv").bind("mouseover mouseout",function (event) {
2. if (event.type == "mouseover") {
3. console.log("鼠标移入");
4. } else if (event.type == "mouseout") {
5. console.log("鼠标移出");
6. }
7. });
实现图片跟随:
1. <!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
2. <html>
3. <head>
4. <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
5. <title>Insert title here</title>
6. <style type="text/css">
7. body {
8. text-align: center;
9. }
10.
11. #small {
12. margin-top: 150px;
13. }
14.
15. #showBig {
16. position: absolute;
17. display: none;
18. }
19. </style>
20. <script type="text/javascript" src="script/jquery-1.7.2.js"></script>
21. <script type="text/javascript">
22. $(function () {
23. $("#small").bind("mouseover mouseout mousemove", function (event) {
24. if (event.type == "mouseover") {
25. //如果是鼠标移入
26. $("#showBig").show();
27. } else if (event.type == "mouseout") {
28. //如果是鼠标移出
29. $("#showBig").hide();
30. } else if (event.type == "mousemove") {
31. $("#showBig").offset({
32. //设置图片的坐标为鼠标坐标加10,这样可以更好地显示内容
33. top: event.pageY + 10,
34. left: event.pageX + 10
35. })
36. }
37. })
38. });
39. </script>
40. </head>
41. <body>
42.
43. <img id="small" src="img/small.jpg"/>
44.
45. <div id="showBig">
46. <img src="img/big.jpg">
47. </div>
48.
49. </body>
50. </html>