打印

BX9048: IE 中 location.reload 方法可以传入 URL 字符串参数使页面进行跳转

作者:钱宝坤

标准参考

无。

问题描述

IE 1 浏览器中 loaction.reload 方法的第一个参数内如果传入 URL 字符串则会导致浏览器将页面重定向到指定 URL 而不是刷新当前页面。

【注】:现有 IE9 Beta 版本中同样存在此问题。

造成的影响

这个问题会导致 IE 浏览器将用户导向新的 URL 地址,而其他浏览器仅会在当前页刷新,造成严重的用户体验差异。

受影响的浏览器

IE  

问题分析

loaction 对象以及其方法属于 BOM ( Browser Object Model ) 范畴,这部分内容至今为止还没有现行规范可以参照,各浏览器都有其私有的实现方式。

loaction 对象的 reload 方法 在 MSDN 与 MDC 中均描述可以传入一个 Boolean 值参数,他决定是否由客户端刷新当前页面。

关于 MSDN  loaction.reload 方法说明清参照: reload Method

关于 MDC  loaction.reload 方法说明清参照: window.location

另外在 HTML5 草案中已经试图将 BOM 部分加入规范描述中,可参见 5.4.3 The Location interface

分析以下代码:

reload 参数:<input value="http://www.google.com/"><br />
<button onclick="location.reload(document.getElementsByTagName('input')[0].value)">
使用 location.reload 方法点击此按钮刷新本页 <br />
参数为上一个 input 的当前 value 字符串
</button><br />
<button onclick="location.reload(1000)">
 location.reload(1000)
</button><br />
<button onclick=" location.reload(true)">
 location.reload(true)
</button><br />
<button onclick=" location.reload(false)">
 location.reload(false)
</button><br />
<button onclick=" location.reload({})">
 location.reload({})

用例中第一个按键点击后使用 location.reload 来刷新本页,其中 reload 方法的参数值来自 INPUT 标记的当前value 属性字符串。根据各浏览器厂商以及 HTML5 草案说明,调用 reload 方法后不管其参数如何都会刷新本页。但是实际情况并非如此,代码中为 reload 方法传入默认的 google.com 地址,并且可以通过修改 INPUT 标记内容达到为这个方法传入不同字符串值的效果。

其后的几个按键点击时分别为 reload 方法传入数值、布尔值和对象类型参数值,他们在各浏览器运行结果如下:

  IE Firefox Chrome Safari Opera
Non-empty string1 页面试图跳转 刷新本页
empty string1 刷新本页
Number
Boolean
Object

【注】:这里的非空字符串以及空字符串不包括特殊的值 '' 和 ' ',他们会导致 IE 触发 loaction 为空的另一个特性,这个问题可以参考文章: BX9035: IE 中 location="" 或 location.href="" 将使页面跳转至当前页面所在根目录

通过上可以看出,仅 IE 浏览器中,当 location.reload 方法的第一个实参值不为空字符串时浏览器会试图把这个字符串当做具体 URL 值,并让页面重新定向到该 URL。这是个很有趣的特性,就连 MSDN 的官方文档上也没有提及他。而其他浏览器则都没有呈现出这个特性。

解决方案

应为空,请避免为 loaction.reload 方法的参数传入非空字符串值。

参见

知识库

相关问题

测试环境

操作系统版本: Windows 7 Ultimate build 7600
浏览器版本: IE6
IE7
IE8
Firefox 3.6.10
Chrome 7.0.544.0 dev
Safari 5.0.2
Opera 10.62
测试页面: location_reload_method.html
本文更新时间: 2010-10-08

关键字

location reload URL 刷新页面 页面跳转