<a href="javascript:void(0)" id="loginlink">login</a>

我见过很多次这样的威胁,但我不知道这到底意味着什么。


当前回答

除了技术答案之外,javascript:void还意味着作者做错了。

没有充分的理由使用javascript:伪URL(*)。在实践中,如果有人尝试“书签链接”、“在新选项卡中打开链接”等操作,这会导致混乱或错误。现在人们已经习惯了用鼠标中键单击新选项卡:它看起来像一个链接,你想在新的选项卡中阅读它,但事实证明它根本不是一个真正的链接,并且在使用鼠标中键时会产生不想要的结果,如空白页面或JS错误。

<a href=“#”>是一种常见的替代方案,可以说可能不那么糟糕。但是,您必须记住从onclick事件处理程序返回false,以防止链接被跟踪并滚动到页面顶部。

在某些情况下,可能有一个实际有用的地方可以指向链接。例如,如果您有一个控件,可以单击它打开一个以前隐藏的<div id=“foo”>,那么使用<a href=“#foo”>链接到它是有意义的。或者,如果有一种非JavaScript的方式来做同样的事情(例如,‘thispage.php?show=foo’将foo设置为可见),您可以链接到它。

否则,如果链接只指向某个脚本,那么它就不是真正的链接,不应该被标记为链接。通常的方法是将onclick添加到不带href的<span>、<div>或<a>中,并以某种方式对其进行样式设置,以明确您可以单击它。这就是StackOverflow〔在撰写本文时所做的;现在它使用了href=“#”〕。

这样做的缺点是你失去了键盘控制,因为你不能点击span/div/bare-a或用空格激活它。这是否真的是一个缺点,取决于元素打算采取什么样的行动。您可以通过在元素中添加tabIndex并监听空格键来尝试模拟键盘的可交互性。但它永远不会100%再现真实的浏览器行为,尤其是因为不同的浏览器对键盘的响应不同(更不用说非视觉浏览器)。

如果你真的想要一个不是链接但可以通过鼠标或键盘正常激活的元素,你需要的是一个<button type=“button”>(或者<input type=“button”>对于简单的文本内容也是一样好的)。如果需要,您可以始终使用CSS对其进行重新设置样式,使其看起来更像链接而不是按钮。但由于它的行为就像一个按钮,所以你真的应该这样标记它。

(*:无论如何,都是在网站内创作。显然,它们对bookmarklets很有用。javascript:伪URL是一种概念上的奇怪之处:一种定位器,它不指向某个位置,而是调用当前位置内的活动代码。它们对浏览器和网络应用程序都造成了巨大的安全问题,网景公司不应该发明它。)

其他回答

你的a标签上应该有一个href。调用返回“undefined”的JavaScript函数就可以了。链接到“#”也是如此。

没有href的Internet Explorer 6中的定位标记不会应用a:hover样式。

是的,这很可怕,是一种轻微的反人类罪行,但总体来说,InternetExplorer6也是如此。

我希望这有帮助。

Internet Explorer 6实际上是一项危害人类的重大罪行。

值得一提的是,检查undefined时有时会看到void 0,因为它需要更少的字符。

例如:

if (something === undefined) {
    doSomething();
}

对比:

if (something === void 0) {
    doSomething();
}

为此,某些缩小方法将undefined替换为void 0。

Web开发人员使用javascript:void(0),因为这是防止标记默认行为的最简单方法。void(*anything*)返回undefined,它是一个错误的值。返回falsy值类似于在标记的onclick事件中返回false,该事件阻止其默认行为。

所以我认为javascript:void(0)是防止标记默认行为的最简单方法。

void运算符计算给定的表达式,然后返回undefined。void运算符通常仅用于获取未定义的原语值,通常使用“void(0)”(相当于“void 0”)。在这些case,全局变量未定义可以使用(假设它有未分配给非默认值值)。

这里提供了一个解释:void运算符。

您希望使用链接的href进行此操作的原因是,通常javascript:URL会将浏览器重定向到评估该javascript结果的纯文本版本。但如果结果未定义,则浏览器将保持在同一页面上。void(0)只是一个短而简单的脚本,其计算结果为undefined。

使用javascript:void(0)意味着HTML的作者误用了锚元素而不是按钮元素。

锚标记经常与onclick事件一起滥用以创建通过将href设置为“#”或“javascript:void(0)”防止页面刷新。这些值会导致意外复制/拖动链接时的行为,在新的标签/窗口、书签以及当JavaScript仍在下载时,出错或被禁用。这也向辅助技术(例如屏幕阅读器)。在这些情况下建议改用<button>。通常,您只应使用使用正确URL导航的锚点。

资料来源:MDN的<a>页面。