IE中JS跳轉(zhuǎn)丟失referrer問題的2個解決方法
曾整理過一個各種頁面跳轉(zhuǎn)方法中referrer丟失的情況,其中提到,在IE中,使用類似 location.href = "a.html"這樣的方式跳轉(zhuǎn)頁面時,在目標(biāo)頁面中 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ù)期地工作,目標(biāo)頁面中 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屬性為目標(biāo)鏈接,然后再使用JS觸發(fā)它的點擊事件。經(jīng)測試,在目標(biāo)頁面也能正常取到 document.referrer。
這個方法代碼更簡短一點,應(yīng)該比上面的使用 form表單的方案更好一些。
相關(guān)文章
JavaScript 中判斷變量是否為數(shù)字的示例代碼
這篇文章主要介紹了JavaScript 中判斷變量是否為數(shù)字的示例代碼,代碼簡單易懂對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-10-10JavaScript中window和document用法詳解
這篇文章主要介紹了JavaScript中window和document用法詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07js監(jiān)聽鍵盤事件的方法_原生和jquery的區(qū)別詳解
下面小編就為大家?guī)硪黄猨s監(jiān)聽鍵盤事件的方法_原生和jquery的區(qū)別詳解。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-10-10基于JS抓取某高校附近共享單車位置 使用web方式展示位置變化代碼實例
這篇文章主要介紹了基于JS抓取某高校附近共享單車位置 使用web方式展示位置變化代碼實例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-08-08JS控件autocomplete 0.11演示及下載 1月5日已更新
JS控件autocomplete 0.11演示及下載 1月5日已更新...2007-01-01