頁面連結跳轉曆史URL不記錄的相容處理

來源:互聯網
上載者:User

標籤:zhang   參數   技術   bsp   zha   turn   切換   而不是   連結   

一、跳轉曆史URL不記錄需求的由來

 

比方說我們點擊首頁的“分類”進入分類頁,如:

然後分類頁頭部有個“男生”“女生”的頻道切換:

這兩個都是直接的連結,如果就會帶來這麼一個問題,如果使用者在“男生”“女生”的頻道之間反覆切換,則當我們點擊左上方的返回按鈕(如)的時候,就會發現點擊很多次還是在“分類頁”上(僅僅頻道不一樣),這其實是不符合使用者預期的。

正常的使用者預期應該是點擊左上方的返回按鈕應該直接回到首頁,而不是還在當前頁過家家。也就是,雖然技術層面使用者剛才的上一頁就是“男生”或是“女生”頻道頁面,但是,我們展現給使用者的互動必須是首頁。

頁面連結跳轉曆史URL不記錄的相容處理
如下fnUrlReplace方法:var fnUrlReplace = function (eleLink) {    if (!eleLink) {        return;    }    var href = eleLink.href;    if (href && /^#|javasc/.test(href) === false) {        if (history.replaceState) {            history.replaceState(null, document.title, href.split(‘#‘)[0] + ‘#‘);            location.replace(‘‘);        } else {             location.replace(href);        }    }};
其中eleLink參數表示<a>連結DOM元素,理論上,fnUrlReplace()方法相容到IE6。
要想實現最終的效果,還需要和事件關聯。舉個簡單的例子,假設頁面上有個<a>連結,希望點擊的時候不進入記錄堆棧,則可以這樣:
document.getElementsByTagName(‘a‘)[0].onclick = function (event) {    if (event && event.preventDefault) {        event.preventDefault();    }    fnUrlReplace(this);    return false;};

 

 

頁面連結跳轉曆史URL不記錄的相容處理

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.