JavaScript void
声明
该文部分代码和内容节选自菜鸟教程,仅用作个人学习,特此声明
JavaScript void
1、javascript:void(0) 含义
我们经常会使用到 javascript:void(0) 这样的代码,那么在 JavaScript 中 javascript:void(0) 代表的是什么意思呢?
javascript:void(0) 中最关键的是 void 关键字, void 是 JavaScript 中非常重要的关键字,该操作符指定要计算一个表达式但是不返回值。
void()仅仅是代表不返回任何值,但是括号内的表达式还是要运行,如
void(alert("Warnning!"))
语法格式如下:
void func()
javascript:void func()
或者
void(func())
javascript:void(func())
下面的代码创建了一个超级链接,当用户点击以后不会发生任何事。
<a href="javascript:void(0)">单击此处什么也不会发生</a>
当用户链接时,void(0) 计算为 0,但 Javascript 上没有任何效果。
以下实例中,在用户点击链接后显示警告信息:
<p>点击以下链接查看结果:</p>
<a href="javascript:void(alert('Warning!!!'))">点我!</a>
以下实例中参数 a 将返回 undefined :
function getValue(){
var a,b,c;
a = void ( b = 5, c = 7 );
document.write('a = ' + a + ' b = ' + b +' c = ' + c );//a=undefined b=5 c=7
}
回忆一下,当时我们如果想让链接标签点击后什么也不发生是这样设置的:href="#"
通过上述例子,href="javascript:void(0)"的功能貌似和上面说的href="#"一样
其实,两者是有区别的
2、href="#"与href="javascript:void(0)"的区别
-
# 包含了一个位置信息,默认的锚点是#top 也就是网页的上端。
-
javascript:void(0), 仅仅表示一个死链接。
-
在页面很长的时候会使用 # 来定位页面的具体位置,格式为:# + id。
-
如果要定义一个死链接应该使用 javascript:void(0) 。
举例如下:
<a href="javascript:void(0);">点我没有反应的!</a>
<a href="#pos">点我定位到指定位置!</a>
<br>
...
<br>
<p id="pos">尾部定位点</p>