1. 程式人生 > >location.reload() 和 location.replace()的區別和應用

location.reload() 和 location.replace()的區別和應用

pan 內存 創建 trac 訪問 親測 能夠 不能 ace

首先介紹兩個方法的語法:

reload 方法,該方法強迫瀏覽器刷新當前頁面。
語法: location.reload([bForceGet])

參數: bForceGet, 可選參數, 默認為 false,從客戶端緩存裏取當前頁。

true, 則以 GET 方式,從服務端取最新的頁面, 相當於客戶端點擊 F5("刷新")

replace 方法,該方法通過指定URL替換當前緩存在歷史裏(客戶端)的項目,因此當使用replace方法之後,你不能通過“前進”和“後退”來訪問已經被替換的URL。
語法: location.replace(URL) 參數: URL

在實際應用的時候,重新刷新頁面的時候,我們通常使用: location.reload() 或者是 history.go(0) 來做。因為這種做法就像是客戶端點F5刷新頁面,所以頁面的method="post"的時候,會出現“網頁過期”的提示。那是因為Session的安全保護機制。可以想到: 當調用 location.reload() 方法的時候, aspx頁面此時在服務端內存裏已經存在, 因此必定是 IsPostback 的。如果有這種應用: 我們需要重新加載該頁面,也就是說我們期望頁面能夠在服務端重新被創建, 我們期望是 Not IsPostback 的。這裏,location.replace() 就可以完成此任務。被replace的頁面每次都在服務端重新生成。你可以這麽寫: location.replace(location.href)

使用replace方法可以防止表單重復提交,親測有用

location.reload() 和 location.replace()的區別和應用