成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

jQuery 事件用法詳解

shiina / 1450人閱讀

摘要:只觸發(fā)事件解除事件任然會執(zhí)行自定義事件把多個(gè)事件組合起來,或者在特定條件下觸發(fā)事件,普通的事件綁定是無法滿足需要的,可以通過自定義事件來形成組合。

jQuery 事件用法詳解 簡介

jquery 之所以成為最受歡迎的前端庫,很大一部分是得益于它的事件具有良好的語義,優(yōu)秀的兼容性,并且便于管理和擴(kuò)展。

在這里我會介紹 jquery 事件的一些比較基礎(chǔ)的用法。

實(shí)現(xiàn)原理

jquery 事件脫胎于瀏覽器的 addEventListener (W3)attachEvent (IE) 方法 , 提供了跨瀏覽器的一致性API。具體的實(shí)現(xiàn)原理可以參考Aaron的系列文章
jquery源碼分析-事件。

事件操作 綁定事件

jquery 中實(shí)現(xiàn)事件綁定有多種方式,其中 $(selector).event(func) 方式中 event 支持一系列的瀏覽器事件,文檔加載事件,表單事件,鍵盤事件和鼠標(biāo)事件,但并非全部。

    // 常用的寫法
    
    $("body").click(function(){ })
    
    $("body").on("click",function(){ })
    
    $("body").one("click",function(){ }) // 只會執(zhí)行一次,然后銷毀事件
    
    // 其他寫法(不推薦)
    $("body").bind("click",function(){ })
    
    $("body").delegate("p","click",function(){ }
    
on.("click").click() 的區(qū)別。

on 屬于 綁定事件處理器(event-handler-attachment) , 而 .click() 屬于 jquery包裝好的鼠標(biāo)事件。

on 可以綁定dom和bom的既有事件,也可以綁定自定義的事件。所以推薦始終只使用$(selector).on(event,func) 的方式,彈性的綁定更多的事件:

    $(document).hashchange(function(){ })// 報(bào)錯(cuò),jquery沒有提供此事件處理器
    
    $(document).on("hashchange",function(){ })// 綁定事件成功
    
綁定多個(gè)事件處理器

也可以同時(shí)綁定多個(gè)事件處理同一事務(wù):

    $("input").on("focus input",function(){ })// 在文本框聚焦和輸入的時(shí)候,都做同樣的事情

或者是綁定多個(gè)事件處理不同事務(wù):

    $("input")
    .on("focus",function(){ })// 聚焦時(shí)處理 
    .on("blur",function(){ })// 失去焦點(diǎn)時(shí)處理 
    .on("input",function(){ })// 輸入時(shí)處理 
    
解除事件

根據(jù)綁定事件方式的不同,解除事件也有好幾種方式。
推薦始終使用 $(selector).off(event) 的方式解除事件綁定,因?yàn)?on/off 正好構(gòu)成了一個(gè)開關(guān)。

    /* 
     * 可以解除 $.click(func),$.on("click",func)和 $.bind("click",func) 綁定的事件,
     * 不能解除delegate方式綁定的事件  
    */ 
    $("body").off("click") 
    
    // 同上
    $("body").unbind("click") 
    
    // 只能解除 delegate方式綁定的事件
    $("body").undelegate("p","click")
觸發(fā)事件

jquery 中,有許多方法根據(jù)其參數(shù)個(gè)數(shù)的不同,既可以是賦值,也可以做為取值操作。
事件也不例外,許多時(shí)候可以利用這個(gè)特性,代替手動去觸發(fā)一些事件,以下示例中的兩種方式,都可以實(shí)現(xiàn)自動觸發(fā)事件。

    // (當(dāng)表單字段未通過驗(yàn)證時(shí)) 自動選中文本值
    $("input").select()
    $("input").trigger("select")
    
    // 觸發(fā)已有的點(diǎn)擊事件
    $(selector).click()
    $(selector).trigger("click")
    
    // 通過觸發(fā)事件,通知select2插件重新渲染
    $("select").change()
    $("select").trigger("change")
事件委托

事件委托通過事件從目標(biāo)元素冒泡到根元素的原理實(shí)現(xiàn),它有2個(gè)好處,一是大幅降低事件綁定的內(nèi)存占用,二是可以對后來加入的元素生效。

    // 寫法
    $(selector).on(event, selector2, func)
    
    // 不推薦的方法
    $(selector).delagate(selector2, event, func)

事件委托原理及性能分析詳見 解密jQuery事件核心 - 委托設(shè)計(jì)(二)

事件操作進(jìn)階

上面列舉了一些簡單的事件綁定,解綁和委托的使用,下面會說到一些更加個(gè)性化的用法。

阻止默認(rèn)事件

event.preventDefault() 這個(gè)方法用于阻止瀏覽器的默認(rèn)行為,通常用于表單提交或是頁面滾動。

    $("form").on("submit",function(event){
          
      // 阻止了默認(rèn)的表單提交事件,下面可以做一些愛做的事情了
      event.preventDefault();
    })
    
    $(document).on("touchmove",function(event){
          
      // 阻止了瀏覽器的默認(rèn)滾動,也可以做些愛做的事情了
      event.preventDefault();
    })
阻止事件傳播

阻止事件傳播即阻止事件繼續(xù)向上冒泡。

    // 點(diǎn)擊div時(shí),會依次alert 2 ,1
    $("body").on("click",function(){alert(1)})
    
    $("div").on("click",function(){alert(2)})
    
    // 下面的代碼只會alert一個(gè) 2,因?yàn)槭录V姑芭萘?不會被body監(jiān)聽到
    $("body").on("click",function(){alert(1)})
    
    $("div").on("click",function(event){
       event.stopPropagation();
       alert(2)
    })
阻止事件向后執(zhí)行

除了阻止默認(rèn)的事件,停止向上冒泡之外,有時(shí)還需要禁止后續(xù)的事件執(zhí)行,可以使用 event.stopImmediatePropagation() 方法。該方法會自動調(diào)用 event.stopPropagation() 方法。

    // 不使用 event.stopImmediatePropagation() 將會alert 2,3,4,1
    // 加上之后只會alert 2
    $("body").on("click",function(){alert(1)})
    
    $("div").on("click",function(event){
       event.stopImmediatePropagation();
       alert(2)
    })
    $("div").on("click",function(){
       alert(3)
    })
    $("div").on("click",function(){
       alert(4)
    })
命名空間

想要更精準(zhǔn)的控制事件,很多時(shí)候還需要利用 jquery 的命名空間機(jī)制。

    $("div").on("click.click1",function(){console.log(1)})
    $("input").on("click.click1",function(){console.log(11)})
    
    $("div").on("click.click2",function(){console.log(2)})
    $("input").on("click.click2",function(){console.log(21)})
    
    // 只觸發(fā)click2事件
    $("div,input").trigger(".click2")
    
    // 解除click1事件,click2任然會執(zhí)行
    $("div,input").off(".click1")
自定義事件

把多個(gè)事件組合起來,或者在特定條件下觸發(fā)事件,普通的事件綁定是無法滿足需要的,可以通過自定義事件來形成 pub-sub 組合。
比如監(jiān)聽 短信驗(yàn)證碼發(fā)送倒計(jì)時(shí)

    // 偽代碼
    
    setInterVal(function(){
      time--;
      if(time < 1){
        $(".js-timeless-button").trigger("time-end", params0, params1);
      }
    },1000)
    
    // 自定義事件回調(diào)函數(shù)默認(rèn)第一個(gè)參數(shù)為event對象,以后的參數(shù)依次是傳入的參數(shù)
    
     $(".js-timeless-button").on("time-end",function(event, params0, params1){
       
     });

或者是 頁面滾動到了底部

    // 偽代碼
    
    $(window).on("scroll",function(){
      if((($(window).scrollTop() + $(window).height())) >= $(document).height()){
        $(document).trigger("infinite", params0, params1);  
      }
    })
    
     $(document).on("infinite",function(event, params0, params1){
       
     });

解除自定義事件和解除其他事件的方式相同??梢酝ㄟ^ off 或者 unbind 進(jìn)行。

事件隊(duì)列

jquery 中,事件是按照其綁定順序依次執(zhí)行的。如果想要調(diào)整執(zhí)行順序,或是禁止之前綁定的方法發(fā)生,可以通過重寫事件隊(duì)列的方式。

查看某個(gè)dom上已綁定事件的方法是
$._data(elem,"events") (jquery版本>1.7)。

elemdom對象 而非 jquery對象 。

    function alertBottle(){
      $("body").on("click",function() { alert("1") });
      $("body").on("click",function() { alert("2") });
      $("body").on("click",function() { alert("3") });
    }
    
    // 點(diǎn)擊body會依次alert 1, 2, 3
    alertBottle();
    
    // 倒序執(zhí)行
    alertBottle();
    
    var Events = $._data($("body").get(0),"events");
    Events.click.sort(function(a,b){return b.guid-a.guid })   
    
    // 禁止執(zhí)行之前的一切, 只執(zhí)行我
    alertBottle();
    
    var Events = $._data($("body").get(0),"events");
    Events.click = null;
    $("body").on("click",function() { alert("4") });
    
    // 最先執(zhí)行我 alert 4, 1, 2, 3
    alertBottle();
    
    $("body").on("click",function() { alert("4") });
    var Events = $._data($("body").get(0),"events");
    var last = Events.click.pop();
    Events.click.unshift(last);

兼容jquery低版本的寫法是:

    $.fn.getEvents = function() {
        if (typeof(jQuery._data) == "function") {
            return jQuery._data(this.get(0), "events") || {};
        } else if (typeof(this.data) == "function") { // jQuery version < 1.7.?
            return this.data("events") || {};
        }
        return {};
    };
    
    // 使用
    $("body").getEvents();

參考資料:jquery中文文檔

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/79767.html

相關(guān)文章

  • 【連載】前端個(gè)人文章整理-從基礎(chǔ)到入門

    摘要:個(gè)人前端文章整理從最開始萌生寫文章的想法,到著手開始寫,再到現(xiàn)在已經(jīng)一年的時(shí)間了,由于工作比較忙,更新緩慢,后面還是會繼更新,現(xiàn)將已經(jīng)寫好的文章整理一個(gè)目錄,方便更多的小伙伴去學(xué)習(xí)。 showImg(https://segmentfault.com/img/remote/1460000017490740?w=1920&h=1080); 個(gè)人前端文章整理 從最開始萌生寫文章的想法,到著手...

    madthumb 評論0 收藏0
  • jQuery入門筆記之(三)事件詳解

    摘要:可以傳遞三個(gè)參數(shù)表示一個(gè)或多個(gè)事件類型,比如。表示綁定到指定元素的處理函數(shù)。我們稱它為簡寫事件。必須在中,并且使用作為事件觸發(fā)元素,不然無效。和表示鼠標(biāo)移入和移出的時(shí)候觸發(fā)。按下返回按下返回和分別表示光標(biāo)激活和丟失,事件觸發(fā)時(shí)機(jī)是當(dāng)前元素。 轉(zhuǎn)自個(gè)人博客 在JavaScript 有一個(gè)非常重要的功能,就是事件驅(qū)動。如果你的網(wǎng)頁需要與用戶進(jìn)行交互的話,就不可能不用到事件。它在頁面完全加...

    GitCafe 評論0 收藏0
  • jQuery 入門詳解(一)

    摘要:前面也花了不少時(shí)間,專門介紹了基礎(chǔ)這一塊,從最基礎(chǔ)的講起,再到以及特效。對象,文檔對象模型,每一份都可以表示成一棵樹。注意選擇器返回的是對象。名稱用法描述相當(dāng)于,子類選擇器相當(dāng)于后代選擇器查找兄弟節(jié)點(diǎn),不包括自己本身。 showImg(https://segmentfault.com/img/remote/1460000013677116?w=1920&h=1080); jQuery ...

    only_do 評論0 收藏0
  • 前端文檔收集

    摘要:系列種優(yōu)化頁面加載速度的方法隨筆分類中個(gè)最重要的技術(shù)點(diǎn)常用整理網(wǎng)頁性能管理詳解離線緩存簡介系列編寫高性能有趣的原生數(shù)組函數(shù)數(shù)據(jù)訪問性能優(yōu)化方案實(shí)現(xiàn)的大排序算法一怪對象常用方法函數(shù)收集數(shù)組的操作面向?qū)ο蠛驮屠^承中關(guān)鍵詞的優(yōu)雅解釋淺談系列 H5系列 10種優(yōu)化頁面加載速度的方法 隨筆分類 - HTML5 HTML5中40個(gè)最重要的技術(shù)點(diǎn) 常用meta整理 網(wǎng)頁性能管理詳解 HTML5 ...

    jsbintask 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<