码迷,mamicode.com
首页 > 其他好文 > 详细

location.reload() 和 location.replace()的区别和应用

时间:2017-12-05 14:30:44      阅读:112      评论:0      收藏:0      [点我收藏+]

标签:网页   期望   实际应用   刷新   创建   load   项目   默认   color   

首先介绍两个方法的语法:

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()的区别和应用

标签:网页   期望   实际应用   刷新   创建   load   项目   默认   color   

原文地址:http://www.cnblogs.com/walblog/p/7986441.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!