stopPropagation()停止事件向上傳播程式碼例項

antzone發表於2017-03-28

本章節介紹一下stopPropagation()函式的作用。

此函式能夠停止事件向上傳播,更準確的說就是阻止事件冒泡效果。

先看一段程式碼例項:

[HTML] 純文字檢視 複製程式碼
<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style type="text/css">
#antzone{
  width:150px;
  height:50px;
  margin:0px auto;
  background:#CCC;
  text-align:center;
  font-size:12px;
}
</style>
<script type="text/javascript">
window.onload=function(){
  var obt=document.getElementById("bt");
  var oantzone=document.getElementById("antzone");
  obt.onclick=function(){
    alert("按鈕物件上的事件觸發");
  }
  oantzone.onclick=function(){
    alert("div上的事件觸發");
  }
}
</script>
</head>
<body>
<div id="antzone">
  <input type="button" id="bt" value="檢視效果"/>
</div>
</body>
</html>

在上面的程式碼中,點選按鈕不但會觸發按鈕上的click事件,並且div上的事件也會觸發,這就是事件冒泡。

下面就用stopPropagation()來阻止事件的冒泡現象。

程式碼如下:

[HTML] 純文字檢視 複製程式碼
<!DOCTYPE html>
<html>
<head>
<meta charset=" utf-8">
<meta name="author" content="http://www.softwhy.com/" />
<title>螞蟻部落</title>
<style type="text/css">
#antzone{
  width:150px;
  height:50px;
  margin:0px auto;
  background:#CCC;
  text-align:center;
  font-size:12px;
}
</style>
<script type="text/javascript">
window.onload=function(){
  var obt=document.getElementById("bt");
  var oantzone=document.getElementById("antzone");
  obt.onclick=function(ev){
    alert("按鈕物件上的事件觸發");
    ev.stopPropagation();
  }
  oantzone.onclick=function(){
    alert("div上的事件觸發");
  }
}
</script>
</head>
<body>
<div id="antzone">
  <input type="button" id="bt" value="檢視效果"/>
</div>
</body>
</html>

上面的程式碼就會出現事件冒泡現象了,因為stopPropagation()可以阻止這一行為。

更多相關stopPropagation()函式相關內容可以參閱javascript stopPropagation()一章節。

相關文章