茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    jQuery 處理頁面的事件詳解
    來源:易賢網(wǎng) 閱讀:1733 次 日期:2015-03-25 11:27:52
    溫馨提示:易賢網(wǎng)小編為您整理了“jQuery 處理頁面的事件詳解”,方便廣大網(wǎng)友查閱!

    這篇文章主要詳細(xì)介紹了jQuery 處理頁面的事件的方法及相關(guān)資料,需要的朋友可以參考下

    在之前dom操作中提到了javascript對事件處理的介紹。由于不同瀏覽器處理事件各不相相同,這給開發(fā)者帶來了不必要的麻煩,jQuery的方便的解決了這個方面的麻煩。

    1.綁定事件監(jiān)聽

    ()對事件的監(jiān)聽做了詳細(xì)的介紹,看到了iE和DOM標(biāo)準(zhǔn)瀏覽器對待事件監(jiān)聽的區(qū)別,并對多個監(jiān)聽事件執(zhí)行順序和方式也不相同。

    在jQuery中,通過bind()對事件綁定,相當(dāng)于IE瀏覽器的attachEvent()和標(biāo)準(zhǔn)DOM的addEventListener()。如下例子:

    代碼如下:

    <script type="text/javascript">

    $(function() {

    $("img")

    .bind("click", function() {

    $("#show").append("<div>點(diǎn)擊事件1</div>");

    })

    .bind("click", function() {

    $("#show").append("<div>點(diǎn)擊事件2</div>");

    })

    .bind("click", function() {

    $("#show").append("<div>點(diǎn)擊事件3</div>");

    });

    });

    </script>

    <img src="11.jpg">

    <div id="show"></div>

    以上代碼對img綁定了三個click監(jiān)聽事件.

    bind()通用語法為

    bind(eventType,[data],Listener)

    其中,eventType為事件的類型,可以是blur/focus/load/resize/scroll/unload/click/dblclick/onmousedown/mouseup/onmouseover/onmouseover/onmouseout/mouseenter/onmouseleave/change/select/submit/onkeydown/keypress/keyup/error

    data為可選參數(shù),用來傳遞一些特殊的數(shù)據(jù)供監(jiān)聽函數(shù)使用。而listener為事件監(jiān)聽函數(shù),上面的例子中使用匿名函數(shù)

    對于多個事件類型,如果希望使用同一個監(jiān)聽函數(shù),可以同事添加在eventType中,事件之間使用空格分離。

    代碼如下:

    $(function() {

    $("p").bind("mouseenter mouseleave", function() {

    $(this).toggleClass("over")

    })

    });

    另外一些特殊的事件類型可以直接利用事件名稱作為綁定函數(shù),接受參數(shù)為監(jiān)聽函數(shù)。例如之前反復(fù)使用的

    代碼如下:

    $("p").click(function(){

    //添加click事件監(jiān)聽函數(shù)

    })

    其中,通用語法為

    eventTypeName(fn)

    可以使用的eventTypeName包括

    blur/focus/load/resize/scroll/unload/click/dblclick/onmousedown/onmouseup/mousemove/mouseover/mouseout/change/select/submit/

    keydown/keypress/keyup/error等

    除了bind()外,jQuery還提供了一個很實(shí)用的one()方法來綁定事件。該方法綁定回見出發(fā)了一次后就會自動刪除,不再生效。

    代碼如下:

    //首先創(chuàng)建10個<div>塊

    for (var i = 0; i < 10; i++)

    $(document.body).append($("<div>Click<br>Me!</div>"));

    var iCounter = 1;

    //每個都用one添加click事件

    $("div").one("click", function() {

    $(this).css({

    background: "#8f0000",

    color: "#FFFFFF"

    }).html("Clicked!<br>" + (iCounter++));

    });

    例如上例,創(chuàng)建10個div,給每個div綁定一個函數(shù)事件,當(dāng)點(diǎn)擊div塊時,函數(shù)執(zhí)行一次便不再執(zhí)行。

    2.移除事件監(jiān)聽

    jQuery采用unbind()來移除事件,該方法可以接受兩個可選函數(shù),也可不設(shè)置任何參數(shù),例如下面的代碼表示移除div標(biāo)記的所有事件和P標(biāo)記的所有click事件。

    代碼如下:

    $("p").unbind("click");

    $("div").unbind();

    如果希望移除某個指定的事件,則必須使用unbind(eventType,listener)方法的第二個參數(shù),例如:

    代碼如下:

    var myFunc = function() {

    //監(jiān)聽函數(shù)體

    };

    $("p").bind("click",myFunc);

    $("p").unbind("click",myFunc);

    例如以下代碼

    代碼如下:

    <script type="text/javascript">

    $(function() {

    var fnMyFunc1; //函數(shù)變量

    $("img")

    .bind("click", fnMyFunc1 = function() { //賦給函數(shù)變量

    $("#show").append("<div>點(diǎn)擊事件1</div>");

    })

    .bind("click", function() {

    $("#show").append("<div>點(diǎn)擊事件2</div>");

    })

    .bind("click", function() {

    $("#show").append("<div>點(diǎn)擊事件3</div>");

    });

    $("input[type=button]").click(function() {

    $("img").unbind("click", fnMyFunc1); //移除事件監(jiān)聽myFunc1

    });

    });

    </script>

    <img src="11.jpg">

    <input type="button" value="移除事件1">

    <div id="show"></div>

    例如以上代碼,添加了fnMyFunc1函數(shù)bind()綁定時將匿名函數(shù)賦值給他,從而作為unbind()函數(shù)調(diào)用名稱。

    3.傳遞事件對象。

    介紹了對象的概念,并且分析了事件對象常用的屬性和方法,可以看到事件對象在不同的瀏覽器之間存在很多區(qū)別,jQuery中沒時間對象是通過唯一的方法傳遞給事件監(jiān)聽函數(shù)的。

    代碼如下:

    <script type="text/javascript">

    $(function() {

    $("p").bind("click", function(e) { //傳遞事件對象e

    var sPosPage = "(" + e.pageX + "," + e.pageY + ")";

    var sPosScreen = "(" + e.screenX + "," + e.screenY + ")";

    $("span").html("<br>Page: " + sPosPage + "<br>Screen: " + sPosScreen);

    });

    });

    </script>

    <p>點(diǎn)擊此處</p>

    <span id=""></span>

    以上的代碼給p綁定了鼠標(biāo)click事件監(jiān)聽函數(shù),并將事件對象作為參數(shù)傳遞,從而獲取了鼠標(biāo)事件觸發(fā)點(diǎn)的坐標(biāo)值。

    對于事件的屬性和方法,jQuery最重要的工作就是替開發(fā)者解決了兼容性問題,常用的屬性和方法

    屬性 說明

    altKey 按下alt鍵為ture,否則為false

    ctrlKey 按下ctrl鍵為ture,否則為false

    shiftKey 按下shift鍵為ture,否則為false

    keyCode 對于keyup和keydown事件,返回按鍵的值(即a和A的值是一樣的,都是65)

    pageX,pageY 鼠標(biāo)在客戶端的位置,不包括工具欄,滾動條等

    relateTarget

    鼠標(biāo)事件中,鼠標(biāo)指針進(jìn)入或離開元素。

    screenX,screenY 鼠標(biāo)在整個屏幕的位置。

    target 引起事件的元素/對象

    type 事件的名稱,如click,mouseover等

    which 鍵盤事件中為按鍵的unicode值,鼠標(biāo)按鍵中代表鼠標(biāo)按鍵(1左鍵 2中鍵 3為右鍵)

    stopPropagation() 阻止事件向上冒泡。

    preventDefault() 阻止事件默認(rèn)行為

    以上即是本文的全部內(nèi)容了,講解的非常詳細(xì),希望大家能夠喜歡。

    更多信息請查看IT技術(shù)專欄

    更多信息請查看腳本欄目
    易賢網(wǎng)手機(jī)網(wǎng)站地址:jQuery 處理頁面的事件詳解
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

    2026國考·省考課程試聽報名

    • 報班類型
    • 姓名
    • 手機(jī)號
    • 驗(yàn)證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機(jī)站點(diǎn) | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
    云南網(wǎng)警備案專用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報警專用圖標(biāo)