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

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


当前回答

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

例如:

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

对比:

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

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

其他回答

链接必须指定href目标,才能使其成为可用的显示对象。

大多数浏览器不会在<a>元素的href中解析高级JavaScript,例如:

<a href="javascript:var el = document.getElementById('foo');">Get element</a>

由于大多数浏览器中的href标记不允许空白或将空白转换为%20(空格的十六进制代码),JavaScript解释器将遇到多个错误。

因此,如果要使用<a>元素的href来执行内联JavaScript,必须首先为href指定一个不太复杂的有效值(不包含空格),然后在事件属性标记中提供JavaScript,如onClick、onMouseOver、onMouseOut等。

典型的答案是这样做:

<a href="#" onclick="var el = document.getElementById('foo');">Get element</a>

这很好,但它会使页面滚动到顶部,因为告诉浏览器这样做。

在<a>元素的href中放置#指定根锚点,默认情况下,根锚点位于页面顶部,但您可以通过在<a<元素中指定name属性来指定不同的位置。

<a name="middleOfPage"></a>

然后,您可以更改<a>元素的href以跳转到middleOfPage并在onClick事件中执行JavaScript:

<a href="#middleOfPage" onclick="var el = document.getElementById('foo');">Get element</a>

很多时候,你不想让链接跳来跳去,所以你可以做两件事:

<a href="#thisLinkName" name="thisLinkCame" onclick="var elem = document.getElementById('foo');">Get element</a>

现在,单击它时,它将无法移动,但可能会导致页面从当前视口重新居中。

使用<a>元素的href使用内联javascript的最佳方法是javascript:void(0);:

<a href="javascript:void(0);" onclick="var el = document.getElementById('foo');">Get element</a>

这告诉浏览器不要去任何地方,而是执行JavaScript:void(0);函数,因为它不包含空格,并且不会被解析为URL。它将由编译器运行。

void是一个关键字,当提供参数0时,该关键字返回undefined,它不使用任何更多的资源来处理在不指定0的情况下会出现的返回值(它更便于内存管理/性能)。

接下来会执行onClick。页面不会移动,显示时不会发生任何事情。

void运算符计算给定的表达式,然后返回undefined。它避免了刷新页面。

#vs javascript:void(0);的行为存在巨大差异;。

#滚动到页面顶部,但javascript:void(0);没有。

如果您正在对动态页面进行编码,这一点非常重要,因为当用户单击页面上的链接时,他们不想返回页首。

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

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

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

我希望这有帮助。

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

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

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

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