亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JQuery中Bind()事件用法分析

 更新時間:2015年05月05日 15:10:28   作者:殘星  
這篇文章主要介紹了JQuery中Bind()事件用法,實例分析了Bind()事件的功能、特點與綁定事件時的使用技巧,需要的朋友可以參考下

本文實例分析了JQuery中Bind()事件用法。分享給大家供大家參考。具體分析如下:

我們先看一下它的定義:

.bind( eventType [, eventData], handler(eventObject))

.Bind()方法的主要功能是在向它綁定的對象上面提供一些事件方法的行為。期中它的三個參數(shù)的意義分別如下:

eventType是一個字符串類型的事件類型,就是你所需要綁定的事件。這類類型可以包括如下:blur, focus, focusin, focusout, load, resize, scroll, unload, click, dblclick, mousedown, mouseup, mousemove, mouseover, mouseout, mouseenter, mouseleave, change, select, submit, keydown, keypress, keyup, error 。這里需要注意的是,這里用的都是javascript里面的事件方法,而不是JQuery里面的,JQuery里面的事件方法均在JavaScript 前面多了一個“on”,比如onclick,onblur 等等。

eventData參數(shù)是一個可選參數(shù),不過它在平時用的比較少。如果提供了這個參數(shù),那么我們就能把一些附加信息傳遞給事件處理函數(shù)了。這個參數(shù)有個很好的用處,就是處理閉包帶來的問題。待會在給大家舉實例。

Handler是用來綁定的處理數(shù),其實也也就是回調(diào)函數(shù),處理完數(shù)據(jù)之后相應(yīng)的方法。

1.第一個簡單的bind ()事件---Hello Word

<input id="BtnFirst"type="button"value="Click Me"/>
<script>
$(function () {
 $("#BtnFirst").bind("click",function(){
  alert("Hello World");
 });
})
</script>

打開頁面之后,點擊按鈕“Click Me”,就會彈出”Hello World”。這算是我們最簡單的綁定事件吧。很簡單吧。

2.綁定多個事件

我們可以通過bind()來綁定多個事件(其實,這也就是JQuery以及Linq中非常有名的鏈式編程)。實現(xiàn)的主要功能就是當我們點擊的時候,彈出“Hello World”,當離開button的時候,顯示出一個div。

<div>
<input id="BtnFirst"type="button"value="Click Me"/></div>
<div id="TestDiv"style=" width:200px; height:200px; display:none; ">
</div>
<script>
$(function () {
 $("#BtnFirst").bind("click", function () {
  alert("Hello World");
 }).bind("mouseout", function () {
  $("#TestDiv").show("slow");
 });
})
</script>

這段代碼頁很容易理解,就是當button被點擊的時候,彈出一個"Hello World",在離開的時候,在把div給顯示出來。JQuery里的動畫,均可以用“slow”、“fast”和“normal”,當然你還可以設(shè)置相關(guān)的毫秒數(shù)。

3.bind()事件的對象

Handler這個回調(diào)函數(shù)可以接受一個參數(shù),當這個函數(shù)被調(diào)用時,一個JavaScript事件對象會作為一個參數(shù)傳進來。

這個事件對象通常是沒有必要且可以省略的參數(shù),因為當這個事件處理函數(shù)綁定的時候就能夠明確知道他在觸發(fā)的時候應(yīng)該做些什么,通常就已經(jīng)可以獲得充分的信息了。然而在有些時候,在事件初始化的時候需要獲取更多關(guān)于用戶環(huán)境的信息。

給一個JQuery官網(wǎng)上面的例子:

<style> 
 p {background:yellow;font-weight:bold;cursor:pointer;3 padding:5px;}
 p.over {background:#ccc;}
 span {color:red;}
</style>
<p>Click or double click here.</p>
<span></span>
<script>
 $("p").bind("click", function(event){
  var str = "( " + event.pageX + ", " + event.pageY + " )";
  $("span").text("Click happened! " + str);
 });
 $("p").bind("dblclick", function(){
  $("span").text("Double-click happened in " + this.nodeName);
 });
 $("p").bind("mouseenter mouseleave", function(event){
  $(this).toggleClass("over");
 });
</script>

這里的主要功能是為了實現(xiàn)當用戶點擊p這個對象的時候,把當前相對于頁面的坐標顯示在span標簽里面,這里就用到了event這個事件。把參數(shù)傳進去。

4.unbind()事件

unbind([type],[data],Handler) 是 bind()的反向操作,從每一個匹配的元素中刪除綁定的事件。如果沒有參數(shù),則刪除所有綁定的事件。你可以將你用bind()注冊的自定義事件取消綁 定。如果提供了事件類型作為參數(shù),則只刪除該類型的綁定事件。如果把在綁定時傳遞的處理函數(shù)作為第二個參數(shù),則只有這個特定的事件處理函數(shù)會被刪除。

<body onclick="MyBodyClick()">
 <div onclick="MyClickOut()">
  <div onclick="MyClickInner()">
   <span id="MySpan">I love JQuery!! </span>
  </div>
 </div>
 <span id="LooseFocus">失去焦點</span>
</body>
<script>
function MyClickOut() {
 alert("outer Div");
}
function MyClickInner() {
 alert("Inner Div");
}
function MyBodyClick() {
 alert("Body Click");
}
var foo = function () {
 alert("I'm span.");
}
$(function () {
 $("#MySpan").bind("click", foo);
})  
$(function () {
 $("#LooseFocus").unbind("click", foo);
})
</script>

上面的代碼也很好理解,就是當用戶的鼠標在span上面停留的時候,然后把span的click事件給取消掉。所以,最后它只會彈出body里面的alert。

最后,簡單的了解一下one()事件的使用,其實one和bind是一樣,都是為了綁定事件而產(chǎn)生的。One與bind基本上差不多,不同的在調(diào)用 jQuery.event.add時,把注冊的事件處理的函數(shù)做了一個小小的調(diào)整。One調(diào)用了jQuery.event.proxy進行了代理傳入的事 件處理函數(shù)。在事件觸發(fā)調(diào)用這個代理的函數(shù)時,先把事件從cache中刪除,再執(zhí)行注冊的事件函數(shù)。這里就是閉包的應(yīng)用,通過閉包得到fn注冊的事件函數(shù) 的引用。 

使用規(guī)則:

one(type,[data],fn)

為每一個匹配元素的特定事件(像click)綁定一個一次性的事件處理函數(shù)。 在每個對象上,這個事件處理函數(shù)只會被執(zhí)行一次。其他規(guī)則與bind()函數(shù)相同。這個事件處理函數(shù)會接收到一個事件對象,可以通過它來阻止(瀏覽器)默認的行為。如果既想取消默認的行為,又想阻止事件起泡,這個事件處理函數(shù)必須返回false。

貼一下,bind和one的各自代碼的實現(xiàn),看官可以稍微的做一個比較:

Bind()代碼的實現(xiàn):

bind : function(type, data, fn) { 
 return type == "unload" ? this.one(type,data,fn) : this.each(function(){
 //fn || data, fn && data實現(xiàn)了data參數(shù)可有可無 
  jQuery.event.add(this, type, fn || data, fn && data); 
 }); 
}

One()代碼的實現(xiàn):

one : function(type, data, fn) { 
 var one = jQuery.event.proxy(fn || data, function(event) { 
  jQuery(this).unbind(event, one); 
  return (fn || data).apply(this, arguments);
 //this->當前的元素 
 }); 
 return this.each(function() { 
  jQuery.event.add(this, type, one, fn && data); 
 }); 
}

5.最后呢,其實想在貼一個冒泡事件,因為在處理綁定事件的時候,如果調(diào)用內(nèi)部的事件 有可能會觸發(fā)外面的事件,所以給大伙一個借鑒吧。

這里可以參考一下javascript事件冒泡的文章:《JavaScript 事件冒泡簡介及應(yīng)用》。

簡單的說,何為冒泡事件?其實,簡單的理解是,也可以說是事件傳播,它會從內(nèi)部的控件廣播到父類的元素,然后接著一直往上到祖先級別的元素。

則 冒泡實例代碼:

<body onclick="MyBodyClick()">
 <div onclick="MyClickOut()">
  <div onclick="MyClickInner()">
    <span id="MySpan">
     I love JQuery!!
    </span>
  </div>
 </div>
</body>
<script type="text/javascript">
 function MyClickOut() {
  alert("outer Div");
 }
 function MyClickInner() {
  alert("Inner Div");
 }
 function MyBodyClick() {    
  alert("Body Click");
 }
 $(function () {
  $("#MySpan").bind("click", function (event) {
   alert("I'm span");
   event.stopPropagation();
 });
</script>

希望本文所述對大家的jQuery程序設(shè)計有所幫助。

相關(guān)文章

最新評論