使用javascript在浏览器中修改网址?

时间:2010-06-16 15:26:19

标签: javascript

是否可以使用javascript更改用户浏览器中的网址而不实际加载网页?我认为不是(可能会导致不必要的行为),我会遇到这样的情况:

我有一个网络应用程序,显示用户生成的报告。布局大致如下:

-----------------------------------------------------------
 Column 1    |   Column 2
-----------------------------------------------------------
  Report A   |
  Report B   |  Currently selected report contents here.
  Report C   |

现在用户会看到如下网址:

www.mysite.com/user123

要查看上面的页面。当用户单击第1列中的报告名称时,我使用ajax在第2列中加载该报告的内容。这对用户来说很方便,但浏览器中的网址保持不变。

用户想要复制报告的网址以便与朋友分享,所以我想我可以提供一个按钮来为他们生成网址,但是他们可以更方便地将其作为网址。他们的浏览器,如:

www.mysite.com/user123/reportb

替代方法是不使用ajax加载第2列中报告的内容,而是整页刷新。这至少会为用户在其网址栏中准备一个可链接的网址,但不如使用ajax方便。

由于

5 个答案:

答案 0 :(得分:6)

您无法以您要求的方式更改它,但是:通常的解决方案是使用window.location.hash,因此网址最终为www.mysite.com/user123#reportb。设置哈希不会导致页面加载。

当用户的朋友点击链接时,由于散列没有发送到服务器,您需要在加载时检查它并执行ajax调用(或者你有什么)来加载所需的报告。

这是(当然)锚定器使用的相同机制,您可能想要或不想使用它。如果没有,请确保您使用的哈希值与页面中的id或锚名称不匹配(如果是,请确保它们确实如此)。

答案 1 :(得分:2)

研究使用JQuery历史插件。它允许在AJAX网站上进行后退/前进导航以及书签(在URL中考虑Facebook样式导航),并且您不必为哈希编写自己的代码/处理程序。

http://plugins.jquery.com/project/history

答案 2 :(得分:0)

有趣!但我觉得更改网址会重新加载页面。为什么不显示带有URL的文本框。您还可以考虑提供一个按钮来直接将URL输入剪贴板(用户无需转到网址栏,选择网址,然后按ctrl + c。

答案 3 :(得分:0)

如果您使用javascript更改网址,则页面将刷新/重新加载。

您可以在不刷新的情况下更改哈希值(#之后的位),但是您的应用程序需要在页面加载时读取它并找出要执行的操作。

window.location.hash = "#reportb";

然后在启动时的代码中

if (window.location.hash == "#reportb") { load report b};

这有点被认为是浏览器中的安全功能。 你不想打一个页面“evilsite.com”,然后网址突然改为“gmail.com”,所以你无法告诉它不是gmail。

答案 4 :(得分:0)

如果您希望所选报告视图可收藏,则不要进行ajax更新。使用网址中包含的选择参数进行整页刷新。