a標(biāo)簽href屬性值對onbeforeunload事件的影響

背景

在某些場景下,我們希望點(diǎn)擊a標(biāo)簽以后不做跳轉(zhuǎn),并且能響應(yīng)a標(biāo)簽綁定的事件,常見方法href設(shè)置javascript:;、#### 等,但經(jīng)測試發(fā)現(xiàn),這幾種方式在chrome,ie9上對onbeforeunload事件的觸發(fā)不一致,這里做個(gè)測試和總結(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è)置一個(gè)比較高的高度,使頁面出現(xiàn)滾動(dòng)條*/
                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é)論

比較.png

1.使用href="" 與使用href="#" 效果是一樣的,都會(huì)滾動(dòng)到頁面頂部
2.a標(biāo)簽不加href屬性,不會(huì)具有a標(biāo)簽的性質(zhì)(hover手形,下劃線),但可以用css加上標(biāo)簽的默認(rèn)樣式
3.對onbeforeunload的觸發(fā)情況:

  • chrome下,href="" 、href="tel"、href="mailto" 都會(huì)觸發(fā)onbeforeunload事件
  • ie下:javascript:void(0); javascript:; href="" 都會(huì)觸發(fā)onbeforeunload事件
    so,

4.在希望點(diǎn)擊a標(biāo)簽以后不做跳轉(zhuǎn),并且能響應(yīng)a標(biāo)簽綁定的事件,而頁面綁定了onbeforeunload事件,href="####", 以及不設(shè)置href屬性這兩種方式是安全的。(href="#"會(huì)有頁面滾動(dòng)到頂部的效應(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

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 問答題47 /72 常見瀏覽器兼容性問題與解決方案? 參考答案 (1)瀏覽器兼容問題一:不同瀏覽器的標(biāo)簽?zāi)J(rèn)的外補(bǔ)...
    _Yfling閱讀 14,154評論 1 92
  • <a name='html'>HTML</a> Doctype作用?標(biāo)準(zhǔn)模式與兼容模式各有什么區(qū)別? (1)、<...
    clark124閱讀 3,836評論 1 19
  • 請參看我github中的wiki,不定期更新。https://github.com/ivonzhang/Front...
    zhangivon閱讀 7,771評論 2 19
  • 做人要會(huì)察言觀色,更要學(xué)會(huì)尊重別人,保護(hù)它人的隱私。敢將隱私說給你聽的人,這份信任值得好好珍惜。 不言人難,不戳人...
    虛懷若谷8閱讀 181評論 0 0
  • HBase隨機(jī)宕機(jī)事件處理 & JVM GC回顧-Hbase-about云開發(fā) http://www.about...
    葡萄喃喃囈語閱讀 455評論 0 1

友情鏈接更多精彩內(nèi)容