亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定

最新edge和firefox測試

<!DOCTYPE html>
<html>
<head>
?<meta charset="UTF-8">
?<script type="text/javascript" src="js/script.js"></script>
?<title>Event測試</title>
</head>
<body>
?<div id="box">
??<input type="button" value="按鈕1" id="btn" onclick="showMes()">
??<input type="button" value="按鈕2" id="btn2">
??<input type="button" value="按鈕3" id="btn3">
??<a href="www.baidu.com" id="go">跳轉</a>
?</div>
?<script type="text/javascript">
??function showMes(event){
???alert("html事件處理程序");
??}
??function showBox(){
???alert("盒子Box");?
??}
??function showM(){
???alert("DOM2級事件處理程序");
??}
??var btn2=document.getElementById('btn2');
??var btn3=document.getElementById('btn3');
??var box=document.getElementById('box');
??//DOM0級事件處理程序
??box.onclick=showBox();
??btn2.onclick=function(){
???alert("DOM0級事件處理程序");
??}//不起作用
??btn2.onclick=function(){
???alert("DOM0級多個事件處理程序");
??}//起作用
?//?btn2.onclick=null; //去掉事件
??//DOM2級事件處理程序
??/*
???DOM2級可以添加多個事件處理程序
??*/
??btn3.addEventListener('click',showM,false);
??btn3.addEventListener('click',function(){alert(this.value)},false);
?//?btn3.removeEventListener('click',showM,false);?//刪除事件
?</script>
</body>
</html>

DOM0級事件不能添加多個事件處理!如代碼,后一個起作用!

最新瀏覽器都支持addEventListener();

問:為何刷新頁面直接執行function showB(){};

而不是冒泡執行?????

正在回答

2 回答

去掉DOM0級事件的box.onclick

在DOM2級事件中添加box.addEventListener('click',showbox,false);可以正常的冒泡??!

猜測應該是html,DOM0級和DOM2級事件的執行順序不同。。。優先級不同。。。


0 回復 有任何疑惑可以回復我~

冒泡執行即點擊按鈕,先執行按鈕事件,在執行按鈕所在的<div>的點擊事件??而刷新頁面直接執行了<div>點擊事件??

0 回復 有任何疑惑可以回復我~

舉報

0/150
提交
取消

最新edge和firefox測試

我要回答 關注問題
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號