亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

js中document.referrer如何實現移動端返回上一頁

發布時間:2021-07-06 11:41:37 來源:億速云 閱讀:214 作者:小新 欄目:web開發

這篇文章主要介紹js中document.referrer如何實現移動端返回上一頁,文中介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們一定要看完!

返回上一頁,在PC端我們可以使用:history.go(-1)或者history.back(),可以正常返回第一層。這樣,我們不需要上一頁的 url 具體是什么,只要使用 history 一般都沒啥問題。

但是在移動端,如果想要返回上一頁。比如從A頁面跳到B頁面,如果B頁面想返回A頁面,為了防止不會跳錯,必須要有一個 <  按鈕,給它加 history.go(-1) ,返回上一層。

<a href="javascript:history.go(-1)" rel="external nofollow" class="header-back jsBack">返回</a>

那如果我們沒有返回上一頁的 < 的按鈕,在手機上怎么操作才會返回上一頁,比如:從微信分享進來的,進入的是微信內頁,此時,內頁就是第一頁,它沒有上一頁,要怎么返回?這時點返回按鈕是沒有反應的,不是一個好的用戶體驗,十有八九的人會誤以為是BUG,這絕對是個坑爸的問題。

移動端無論是原生app還是傳統的網頁,返回上頁是一個比較強烈的需求。

javascript 有一個可以獲取前一頁面的URL地址的方法:document.referrer

document.referrer 的來源

  1. referrer 屬性可返回載入當前文檔的文檔的 URL【摘自W3CSHCOOL】, 如果當前文檔不是通過超鏈接訪問的,那么當前文檔的URL為NULL,這個屬性允許客戶端的 javascript 訪問 HTTP 頭部;

  2. referrer 屬性,我們可以從 http 頭部獲取

document.referrer 的兼容性

document.referrer IE7都支持,它的兼容性比較高,Android 5.0開始支持,iOS都支持,PC端瀏覽器從IE7就開始支持了,兼容性沒有什么大的問題。

但是有個小小的問題,就是 IE 會主動清除 referref 屬性。在IE中用javascript做跳轉,比如用window.location.href = “”; google如果使用document.referrer無法取到瀏覽器請求的HTTP referrer,因為IE清空了。而其他主流瀏覽器Firefox和Chrome都會保留referrer,沒辦法,只好判斷,如果是IE瀏覽器,就主動給它增加一個 referrer 。這樣的原理就是給IE瀏覽器的頁面偷偷加了個鏈接,然后自動點這個鏈接,于是referrer就能保留了。

var url = 'https://www.jb51.net'; 
if (/MSIE (\d+\.\d+);/.test(navigator.userAgent) || /MSIE(\d+\.\d+);/.test(navigator.userAgent)) 
{ 
 var referLink = document.createElement('a'); 
 referLink.href = url; 
 document.body.appendChild(referLink); 
 referLink.click(); 
} 
else 
{ 
 location.href = url; 
}

document.referrer 的牛X做法

解決移動端返回上一頁的問題,就是上面所說的微信分享的問題?根據【張鑫旭】大神的方法是,既然點擊上一頁沒有反應,就讓它返回首頁,從首頁再進入其它子頁面,應該沒啥問題。

1.根據 document.referrer 的來源來判斷是否有來源信息,如果沒有,則返回首頁:

if (typeof document.referrer === '') {
 // 沒有來源頁面信息的時候,改成首頁URL地址
 $('.jsBack').attr('href', '/');
}

這樣,當再次點擊返回按鈕時,就可以返回首頁了。

2.根據 document.referrer 的來源url 是否為網站的 url,如果判斷這個 url 的來路有問題,則屏蔽該 url 下的所有信息,比如不讓其顯示圖片等。可以有效的防止盜鏈,目前百度統計,google ads統計,CNZZ統計,都是用的這個方法。

無法獲取 referrer 信息的情況

下面的場景無法獲得 referrer 信息:

  1. 直接在瀏覽器中輸入地址

  2. 使用location.reload()刷新(location.href或者location.replace()刷新有信息)

  3. 在微信對話框中,點擊進入微信自身瀏覽器

  4. 掃碼進入微信或QQ的瀏覽器

  5. 直接新窗口打開一個頁面

  6. 從https的網站直接進入一個http協議的網站(Chrome下親測)

  7. a標簽設置rel="noreferrer"(兼容IE7+)

  8. meta標簽來控制不讓瀏覽器發送referer

  9. 點擊 flash 內部鏈接

  10. Chrome4.0以下,IE 5.5+以下返回空的字符串

  11. 使用 修改 Location 進行頁面導航的方法,會導致在IE下丟失 referrer,這可能是IE的一個BUG

  12. 跨域

<meta content="never" name="referrer">

怎么解決無法獲取 referrer 的情況,還沒有很好的方法,盡量避免吧。

以上是“js中document.referrer如何實現移動端返回上一頁”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

淄博市| 嘉善县| 青神县| 顺昌县| 海晏县| 嘉义市| 筠连县| 明溪县| 萨嘎县| 延安市| 响水县| 泰宁县| 岳阳市| 繁峙县| 酉阳| 石门县| 小金县| 浦北县| 温州市| 深圳市| 绥滨县| 鲁甸县| 敖汉旗| 岐山县| 汶川县| 镇康县| 昆明市| 建水县| 孝感市| 横峰县| 汝阳县| 芒康县| 崇仁县| 镇平县| 长寿区| 和龙市| 双桥区| 盐城市| 资阳市| 泰州市| 乐业县|