解決安卓微信瀏覽器中location.reload 或者 location.href失效的問題


在移動wap中,經常會使用window.location.href去跳轉頁面,這個方法在絕大多數瀏覽器中都不會 
存在問題,但早上測試的同學會提出了一個bug:在安卓手機的微信自帶瀏覽器中,這個是失效的,並沒有跳轉;

原來的代碼:

window.location.reload(location.href);

初步判斷可能是緩存的問題,首先想到的解決辦法就是在要跳轉的url后面加個時間戳,告知瀏覽器這是一個新的請求;

window.location.reload(location.href+'?time='+((new Date()).getTime()));

然而並沒有什么卵用,看了下js文檔:


href是location對象的一個屬性,reload()則是location對象的方法
所以對於href,可以為該屬性設置新的 URL,使瀏覽器讀取並顯示新的 URL 的內容。
對於reload()則是重新加載當前文檔,如果該方法沒有規定參數,或者參數是 false,它就會用 HTTP 頭 If-Modified-Since 來檢測服務器上的文檔是否已改變。如果文檔已改變,reload() 會再次下載該文檔。如果文檔未改變,則該方法將從緩存中裝載文檔。這與用戶單擊瀏覽器的刷新按鈕的效果是完全一樣的。如果把該方法的參數設置為 true,那么無論文檔的最后修改日期是什么,它都會繞過緩存,從服務器上重新下載該文檔。這與用戶在單擊瀏覽器的刷新按鈕時按住 Shift 健的效果是完全一樣。

但對於安卓手機微信中的瀏覽器,reload只是從緩存中裝載文檔,所以當你使用該方法,是失效的;

 

解決辦法就是,使用location.href代替reload(),而且在以后的使用中也強烈建議大家使用location.href來進行刷新或者跳轉

window.location.href = location.href+'?time='+((new Date()).getTime());

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM