淺談jquery事件處理

來源:互聯網
上載者:User

淺談jquery事件處理

   淺談jquery事件處理

        在以jQuery為基礎庫的前端開發體系中,經常會在一個頁面上通過各種標識綁定許許多多的事件。就算簡單的使用了事件代理,也還是造成了事件的分散,不好維護和管理。

  那麼,如何解決這個問題呢?而我,想到了backbone中的events。如下:

   代碼如下:

  events: {

  "click .icon": "open",

  "click .button.edit": "openEditDialog",

  "click .button.delete": "destroy"

  }

  也就是,把事件聚集到一起,類似事件處理中心這麼一個概念。

  簡單的理了一下實現思路:

  使用事件代理的方式,將事件綁定到body節點。(某些事件自身是不冒泡的,在此暫時不做研究)

  對於事件的執行對象,給一個統一標識。

  事件的執行函數,集中處理。

  代碼如下:

  

  

 

 

  

 

 

  

  // 事件處理中心

  var ClickEventCenter = {

  "handler1": function () {

  // do something...

  },

  "handler2": function () {

  // do something...

  }

  // ...

  }

  // 事件綁定

  $body.on("click", "[data-click-center]", function () {

  var handlerName = $(this).data("click-center");

  var handler = ClickEventCenter[handlerName]

  if ($.isFunction(handler)) handler()

  })

  這樣的話,一種類型的事件,集中到一起。

  在某些時候,能夠起到很好的作用。

  以上所述就是本文的全部內容了,希望大家能夠喜歡。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.