1. 程式人生 > >解決安卓微信瀏覽器中location.reload 或者 location.href失效的問題

解決安卓微信瀏覽器中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());