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>