首頁  >  文章  >  web前端  >  IE中JS跳轉丟失referrer問題的2個解決方法_javascript技巧

IE中JS跳轉丟失referrer問題的2個解決方法_javascript技巧

WBOY
WBOY原創
2016-05-16 16:41:421408瀏覽

曾整理過一個各種頁面跳轉方法中referrer丟失的情況,其中提到,在IE中,使用類似location.href = "a.html"這樣的方式跳轉頁面時,在目標頁面中document.referrer的值會是空。這應該是IE的一個 bug。

大多數情況下,這個問題不會給我們帶來麻煩,但有時候我們不得不用JavaScript來跳轉,同時又要在下一個頁面收集 document.refer,這時就得想想其他辦法了。

Form GET方法

首先想到的是使用Form表單,用JS發起一個GET請求。程式碼類似下面這樣:

複製程式碼 程式碼如下:

function goToPage(url) {
    if (isIE) {
        // IE瀏覽器
        var frm = document.createElement("form");
        frm.action = url;
        frm.method = "GET";
        document.body.appendChild(frm);
        frm.submit();
    } else {
        // 非IE
        location.href = url;
    }
}

這個方法可以如同預期地工作,目標頁面中 document.referrer能正常指向上一個頁面。

A元素模擬點擊方法

網路上搜尋了一下,發現司徒正美的部落格上記錄了這個問題的另一個處理方法:

複製程式碼 程式碼如下:

//define for all browsers
function goto(url) {
    location.href = url;
}

//re-define for IE
if (isIE) {
    function goto(url) {
        var referLink = document.createElement('a');
        referLink.href = url;
        document.body.appendChild(referLink);
        referLink.click();
    }
}

原理很簡單,先創建了一個 A元素,指定其 href屬性為目標鏈接,然後再使用JS觸發它的點擊事件。經測試,在目標頁面也能正常取到 document.referrer。

這個方法程式碼短一點,應該比上面的使用 form表單的方案好一些。

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn