IE中JS跳轉(zhuǎn)丟失referrer問題的2個解決方法

字號:


    這篇文章主要介紹了IE中JS跳轉(zhuǎn)丟失referrer問題的2個解決方法,算是IE的一個BUG吧,本文提供了2個方法解決這個問題,需要的朋友可以參考下。
    曾整理過一個各種頁面跳轉(zhuǎn)方法中referrer丟失的情況,其中提到,在IE中,使用類似 location.href = "a.html"這樣的方式跳轉(zhuǎn)頁面時,在目標頁面中 document.referrer的值會是空。這應(yīng)該是IE的一個 bug。
    大多數(shù)情況下,這個問題不會給我們帶來麻煩,但有時候我們不得不用JavaScript來跳轉(zhuǎn),同時又要在下一個頁面收集 document.refer,這時就得想想其他辦法了。
    Form GET方法
    首先想到的是使用Form表單,用JS發(fā)起一個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;
        }
    }
    這個方法可以如同預(yù)期地工作,目標頁面中 document.referrer能正常指向上一個頁面。
    A元素模擬點擊方法
    網(wǎng)上搜索了一下,發(fā)現(xiàn)司徒正美的博客上記錄了這個問題的另一個處理方法:
    代碼如下:
    //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();
        }
    }
    原理很簡單,先創(chuàng)建了一個 A元素,指定其 href屬性為目標鏈接,然后再使用JS觸發(fā)它的點擊事件。經(jīng)測試,在目標頁面也能正常取到 document.referrer。
    這個方法代碼更簡短一點,應(yīng)該比上面的使用 form表單的方案更好一些。