大多數情況下,這個問題不會給我們帶來麻煩,但有時候我們不得不用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表單的方案更好一些。
聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com