首頁 web前端 js教程 Js 冒泡事件阻止實作程式碼_javascript技巧

Js 冒泡事件阻止實作程式碼_javascript技巧

May 16, 2016 pm 05:42 PM
事件冒泡 冒泡事件

1. 事件目標

現在,事件處理程序中的變數event會保存事件物件。而event.target屬性則保存著發生事件的目標元素。這個屬性是DOM API中規定的,但是沒有被所有瀏覽器實作 。 jQuery對這個事件物件進行了必要的擴展,從而在任何瀏覽器中都能夠使用這個屬性。透過.target,可以確定DOM中首先接收到事件的元素(即實際被點擊的元素)。而且,我們知道this引用的是處理事件的DOM元素,所以可以寫下列程式碼:

複製程式碼 程式碼如下:

$(document).ready(function(){
 $('#switcher').click(function(event){
  $('#switcher .button'). toggleClass('hidden');
  })
 })

$(document).ready(function(){
 $('#switcher').click(function(event ){
  if(event.target==this){
  $('#switcher .button').toggleClass('hidden');
  }
  })
 })
 

此時的程式碼確保了被點擊的元素是
,而不是其他後代元素。現在,點擊按鈕不會再折疊樣式轉換器,而點擊邊框則會觸發折疊操作。但是,點擊標籤同樣什麼也不會發生,因為它也是一個後代元素。實際上,我們可以不把檢查程式碼放在這裡,而是透過修改按鈕的行為來達到目標 。

2. 停止事件傳播

事件物件也提供了一個.stopPropagation()方法,該方法可以完全阻止事件冒泡。與.target類似,這個方法也是一種純JavaScript特性,但在跨瀏覽器的環境中則無法安全地使用 。不過,只要我們透過jQuery來註冊所有的事件處理程序,就可以放心地使用這個方法。
下面,我們會刪除剛剛新增的檢查語句event.target == this,並在按鈕的點擊處理程序中加入一些程式碼:

複製程式碼 程式碼如下:

$(document).ready(>

$(document).ready(function(){ $('#switcher .button').click(funtion(event){
  //…
   event.stopPropagation();
  })
 })
>

  同以前一樣,需要為用作點選處理程序的函數新增一個參數,以便存取事件物件。然後,透過簡單地呼叫event.stopPropagation()就可以避免其他所有DOM元素回應這個事件。這樣一來,點選按鈕的事件會被按鈕處理,而且只會被按鈕處理。點擊樣式轉換器的其他地方則可以折疊和擴展整個區域。

3. 預設操作


如果我們把點擊事件處理程序註冊到一個錨元素,而不是一個外層的

上,那麼就要面對另一個問題:當使用者點擊連結時,瀏覽器會載入一個新頁面。這種行為與我們討論的事件處理程序不是同一個概念,它是單擊錨元素的預設操作。類似地,當使用者在編輯完表單後按下回車鍵時,會觸發表單的submit事件,在此事件發生後,表單提交才會真正發生。
如果我們不希望執行這種預設操作,那麼在事件物件上呼叫.stopPropagation()方法也無濟於事,因為預設操作不是在正常的事件傳播流中發生的。在這種情況下,.preventDefault()方法則可以在觸發預設操作之前終止事件 。
提示 當在事件的環境中完成了某些驗證之後,通常會用到.preventDefault()。例如,在表單提交期間,我們會對使用者是否填寫了必填字段進行檢查,如果使用者沒有填寫相應字段,那麼就需要阻止預設操作。我們將在第8章詳細討論表單驗證。 事件傳播和預設操作是相互獨立的兩套機制,在二者任何一方發生時,都可以終止另一方。如果想要同時停止事件傳播和預設操作,可以在事件處理程序中傳回false,這是對在事件物件上同時呼叫.stopPropagation()和.preventDefault()的一種簡寫方式。


補充:

程式碼如下:

//點選按鈕事件(改變文字樣式)
$(document).ready(function() {
   $('#switcher .button').click(function() {
     $('body').removeClass();
     if (this.id == 'switcher-narrow') {
     >     }
     else if (this.id == 'switcher-large') {
       $('body').addClass('large');; #switcher .button').removeClass('selected');
     $(this).addClass('selected');
   });
});
>
//點選按鈕外層div出發事件(隱藏按鈕)
$(document).ready(function() {
   $('#switcher').click(function() {     $('#switcher .button').toggleClass('hidden');

   });
});


現在的問題是,當點擊了按鈕時,同時觸發了隱藏按鈕事件。這是事件冒泡導致。
為了阻止事件冒泡,需要為隱藏按鈕函數增加一個參數:




複製程式碼
程式碼如下: $(document).ready(function() {   $('#switcher').click(function(even) {
     if(even.target==this){
     if(even.target==this){       $('#switcher .button').toggleClass('hidden');
     }
   });
});

   });
}); target屬性保存發生事件的目標元素。可以確定DOM中首先接收到事件的元素。此時程式碼確保了被點擊的是
,而不是其後代元素。

也可以這樣處理,透過修改按鈕的行為來達到目的。


複製程式碼

程式碼如下:$(document).ready(>
$(document).ready(unction() {   $('#switcher .button').click(function(even) {
     $('body').removeClass();
     if (this.id == 'switcher-n>     if (this.id == 'switcher-num  '
       $('body').addClass('narrow');
     }
     else if (this.id == 'switcher-large') { ('large');
     }

     $('#switcher .button').removeClass('selected');
  >     even.stopPropagation();
   });
});




用JS阻止事件冒泡
事件冒泡: 當一個元素上的事件被觸發的時候,比如說滑鼠點擊了一個按鈕,同樣的事件將會在那個元素的所有祖先元素中被觸發。這個過程被稱為事件冒泡;這個事件從原始元素開始一直冒泡到DOM樹的最上層。

可以用JS來阻止js事件冒泡。因為瀏覽器的差異IE和FF的JS寫法有點不一樣。 IE用cancelBubble=true來阻止而FF下需要用stopPropagation方法。 下一個完整的程式碼:




複製程式碼

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

了解事件冒泡機制:為何子元素的點擊會影響父元素的事件? 了解事件冒泡機制:為何子元素的點擊會影響父元素的事件? Jan 13, 2024 pm 02:55 PM

理解事件冒泡:為什麼子元素的點擊會觸發父元素的事件?事件冒泡是指在一個嵌套的元素結構中,當子元素觸發某個事件時,該事件會像冒泡一樣逐層傳遞到父元素,直到最外層的父元素。這種機制使得子元素的事件可以在整個元素樹中傳遞,並依序觸發所有相關的元素。為了更好地理解事件冒泡,讓我們來看一個具體的範例程式碼。 HTML程式碼:<divid="parent&q

jQuery .val()失效的原因及解決方法 jQuery .val()失效的原因及解決方法 Feb 20, 2024 am 09:06 AM

標題:jQuery.val()失效的原因及解決方法在前端開發中,經常會使用jQuery來操作DOM元素,其中.val()方法被廣泛用於獲取和設定表單元素的值。然而,有時候我們會遇到.val()方法失效的情況,導致無法正確取得或設定表單元素的值。本文將探討造成.val()失效的原因,並提供對應的解決方法,同時附上具體的程式碼範例。 1.原因分析.val()方法

事件冒泡為何會觸發兩次? 事件冒泡為何會觸發兩次? Feb 22, 2024 am 09:06 AM

事件冒泡為何會觸發兩次?事件冒泡(EventBubbling)是指在DOM中,當一個元素觸發了某個事件(例如點擊事件),該事件會從該元素開始向上冒泡至父元素,直到冒泡到最頂層的文檔對象為止。事件冒泡是DOM事件模型的一部分,它允許開發者將事件監聽綁定到父元素,從而在子元素觸發事件時,可以透過冒泡機制來捕獲並處理事件。然而,有時開發者會遇到事件冒泡觸發兩次的

js中點擊事件為什麼不能重複執行 js中點擊事件為什麼不能重複執行 May 07, 2024 pm 06:36 PM

JavaScript 中的點擊事件無法重複執行,原因在於事件冒泡機制。為了解決此問題,可以採取以下措施:使用事件擷取:指定事件偵聽器在事件冒泡之前觸發。移交事件:使用 event.stopPropagation() 阻止事件冒泡。使用計時器:在一段時間後再次觸發事件偵聽器。

哪些JS事件不會往上冒泡? 哪些JS事件不會往上冒泡? Feb 19, 2024 pm 09:56 PM

JS事件中有哪些不會冒泡的狀況?事件冒泡(EventBubbling)是指在觸發了某個元素的事件後,事件會從最內層元素開始沿著DOM樹向上傳遞,直到最外層的元素,這種傳遞方式稱為事件冒泡。但是,並不是所有的事件都能冒泡,有一些特殊情況下事件是不會冒泡的。本文將介紹在JavaScript中有哪些情況下事件不會冒泡。一、使用stopPropagati

為何事件冒泡機制會觸發兩次? 為何事件冒泡機制會觸發兩次? Feb 25, 2024 am 09:24 AM

為什麼事件冒泡會連續發生兩次?事件冒泡是web開發中重要的概念,它指的是當一個事件在嵌套的HTML元素中觸發時,事件會從最內層的元素開始一直冒泡到最外層的元素。這個過程有時會引起困惑,其中一個常見問題就是事件冒泡會連續發生兩次。為了更好的理解為什麼事件冒泡會連續發生兩次,我們先來看一段程式碼範例:

vue中的事件修飾符可以用於哪些場景 vue中的事件修飾符可以用於哪些場景 May 09, 2024 pm 02:33 PM

Vue.js 事件修飾符用於新增特定行為,包括:阻止預設行為(.prevent)停止事件冒泡(.stop)一次性事件(.once)擷取事件(.capture)被動的事件監聽(.passive)自適應修飾符(.self)關鍵修飾符(.key)

冒泡事件的常見阻止方法有哪些? 冒泡事件的常見阻止方法有哪些? Feb 19, 2024 pm 10:25 PM

常用的阻止冒泡事件指令有哪些?在Web開發中,我們經常會遇到需要處理事件冒泡的情況。當一個元素上觸發了某個事件,例如點擊事件,它的父級元素也會觸發相同的事件。這種事件傳遞的行為稱為事件冒泡。有時候,我們希望阻止事件冒泡,使事件只在當前元素上觸發,並阻止其向上級元素傳遞。為了實現這個目的,我們可以使用一些常見的阻止冒泡事件的指令。 event.stopPropa

See all articles