Javascript 当window.location=self.location不';行不通
在我的主页上,我看到:Javascript 当window.location=self.location不';行不通,javascript,browser,caching,reload,Javascript,Browser,Caching,Reload,在我的主页上,我看到: <ul id="login"> <li> <a id="loginswitch" href="./login-page">log-in</a> | </li> <li> <a id="signupswitch" href="./signup-page">sign-up</a> </li> </ul> 这个系统工作得很好-现在我想知道为什么如果我
<ul id="login">
<li> <a id="loginswitch" href="./login-page">log-in</a> | </li>
<li> <a id="signupswitch" href="./signup-page">sign-up</a> </li>
</ul>
这个系统工作得很好-现在我想知道为什么如果我将锚定“href
值更改为href=“#”
我的脚本将不再工作
这和窗户有关吗
当我点击一个链接或者当事件的传播停止时,它是否改变了它的属性??转到页面上的锚点-
#
表示的是-,不需要重新加载
window.location = self.location;
此JavaScript正在执行
当它执行时,浏览器被告知用新值替换window.location
的值并非所有浏览器在这里的反应都相同。有些可能会像您预期的那样工作,但其他人会对此很聪明,并比较这两个值浏览器知道它在哪一页,它知道你只是要求它转到同一页
浏览器缓存
浏览器甚至在缓存中有当前页面的副本。它可以与服务器对话,询问缓存中的页面是否仍然有效。如果缓存有效,它可能会决定不强制重新加载页面。在幕后,这种情况发生在HTTP头上。浏览器和服务器可以通过HTTP以多种方式进行通信。在这种情况下,浏览器会向服务器发送一个快速请求,内容如下:
GET /stackoverflow.com/posts/196643/index.html
HTTP/1.1
Host: www.stackoverflow.com
User-Agent: Mozilla/5.0
If-Modified-Since: Sun, 12 Oct 2008 20:41:31 GMT
这称为条件GET请求。如果您的浏览器说“如果自”之后进行了修改,则表示“将该文件提供给我,但前提是自上次看到该文件以来该文件已被修改。”
长话短说,您没有明确告诉浏览器重新加载页面
您可以这样做:
location.reload( true );
“true”是一个可选参数,用于强制重新加载。浏览器甚至不会查看缓存。它会照你说的做。如果他们在工作中把这个特殊任务交给我,我会把它退回到设计上来。除非我们讨论的是安全页面或OpenID登录,否则您不应该弹出登录或登录表单。用户需要学会在页面顶部查找https:,如果看不到,就永远不要登录
location.reload( true );