背景
在某些場景下侨艾,我們希望點擊a標(biāo)簽以后不做跳轉(zhuǎn)炎辨,并且能響應(yīng)a標(biāo)簽綁定的事件垫释,常見方法href設(shè)置javascript:;丝格、#### 等,但經(jīng)測試發(fā)現(xiàn)棵譬,這幾種方式在chrome显蝌,ie9上對onbeforeunload事件的觸發(fā)不一致,這里做個測試和總結(jié)订咸。
示例代碼
示例代碼里對幾種不同的方式在chrome,ie下作了測試曼尊。
-- chrome版本:版本 58.0.3029.110
-- ie版本:9.0.8112
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<style type="text/css">
.container {
margin-bottom: 64px;
}
.content {
height: 2000px; /*設(shè)置一個比較高的高度,使頁面出現(xiàn)滾動條*/
background: #f0f0f0;
}
.item {
margin-top: 12px;
}
</style>
</head>
<body>
<div class="container">
<div class="content">
測試a標(biāo)簽
</div>
<div>
<div class="item"><a href="javascript:void(0);" >test1-使用void</a> </div>
<div class="item"><a href="javascript:;" >test2-使用javascript:;</a> </div>
<div class="item"><a href="####" >test3-使用####</a></div>
<div class="item"><a href="#">test4-使用#</a></div>
<div class="item"><a class="">test5-不加href屬性</a></div>
<div class="item"><a href="">test6-href屬性值為空</a></div>
<div class="item"><a href="tel:18822222222">test7-打電話</a></div>
<div class="item"><a href="mailto:xxx@163.com">test8-發(fā)郵件</a></div>
</div>
</div>
</body>
<script type="text/javascript">
window.onbeforeunload = function(e) {
e.returnValue = '';
}
</script>
</html>
結(jié)論
1.使用href="" 與使用href="#" 效果是一樣的脏嚷,都會滾動到頁面頂部
2.a標(biāo)簽不加href屬性涩禀,不會具有a標(biāo)簽的性質(zhì)(hover手形,下劃線)然眼,但可以用css加上標(biāo)簽的默認(rèn)樣式
3.對onbeforeunload的觸發(fā)情況:
- chrome下,href="" 葵腹、href="tel"高每、href="mailto" 都會觸發(fā)onbeforeunload事件
- ie下:javascript:void(0); javascript:; href="" 都會觸發(fā)onbeforeunload事件
so,
4.在希望點擊a標(biāo)簽以后不做跳轉(zhuǎn),并且能響應(yīng)a標(biāo)簽綁定的事件践宴,而頁面綁定了onbeforeunload事件鲸匿,href="####", 以及不設(shè)置href屬性這兩種方式是安全的。(href="#"會有頁面滾動到頂部的效應(yīng))
5.但是阻肩,如果使用了javascript:;的方式带欢,可以在a標(biāo)簽的響應(yīng)事件里加上运授,return false; 或者e.preventDefault() 來解決ie9下頻繁彈出頁面離開提示的問題
Reference
1.onebeforeunload is too enthusiastice in ie9 https://stackoverflow.com/questions/7263309/onbeforeunload-event-is-too-enthusiastic-in-ie9