在移動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());