是否有可能有一个正常的链接指向当前位置?

我目前找到了2个解决方案,但其中一个包括JavaScript,在另一个你必须知道页面的绝对路径:

<a href="#" onclick="window.location.reload(true);">1</a>
<a href="/foobar/">2</a>
<a href="#">3 (of course not working)</a>

有没有办法做到这一点,而不使用JavaScript或知道绝对路径?


当前回答

不幸的是,只有HTML没有全局的方法来做到这一点。你可以尝试做<a href="">test</a>,但它只适用于某些浏览器。

其他回答

虽然在IE9中接受的答案不适合我,但这个却可以:

<a href="?">link</a>

我使用JS在jekyll网站的标签页中仅显示具有特定id的div。对于同一页面中的一组链接,您可以显示相应的元素:

function hide_others() {
    $('div.item').hide();
    selected = location.hash.slice(1);
    if (selected) {
        $('#' + selected).show();
    }
    else {
    $('div.item').show();
    }
}

链接使用如下链接:

<a href="javascript:window.location.href='/tags.html#{{ tag[0] }}-ref'; hide_others()">{{ tag[0] }}</a>

对我来说,之前这里提供的答案是打开一个新的标签/窗口(可能是因为我的浏览器设置)。但是我想在同一页面上重新加载/刷新。所以,上面的解决方案对我来说并不管用。

然而,好消息是,以下两种方法中的任何一种都对我有用。

<一个onclick = " javascript: window.location.reload ();“刷新> < / > <一个onclick = " window.location.href =这" > < / >刷新

其他答案都不会保留任何查询字符串值。试一试

<a href="javascript:window.location.href=window.location.href">

不可否认,这涉及到javascript,但除非你的用户禁用了脚本,这是相当简单的。

还有一个解决方案

<a href="javascript:history.go(0)">Reload</a>