标题含有⾮法字符,请修改(标题如下)javascript:;与javascript:void(0)使⽤介绍(标题)
有时候我们在编写js过程中,需要触发事件⽽不需要返回值,那么就可能需要这样的写法。
注:以下代码未经全⾯测试,但每⼀种⽅法可能会出现的情况都基本做了说明。
在做页⾯时,如果想做⼀个链接点击后不做任何事情,或者响应点击⽽完成其他事情,可以设置其属性 href = “#”,但是,这样会有⼀个问题,就是当页⾯有滚动条时,点击后会返回到页⾯顶端,⽤户体验不好。
⽬前有如下⼏种解决办法:
1)点击链接后不做任何事情
复制代码
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title></title>
<script src="jquery-1.11.1.min.js"></script>
</head>
<body>
<!--no click event-->
<div >height</div>
<a href="javascript:void(0);">javascript:void(0);不含点击事件</a>
<a href="javascript:;">javascript:;不含点击事件</a>
<a href="####">#### 不含点击事件</a>
<a>不含href及点击事件</a>
<!--点击事件-->
<a href="javascript:void(0);" onclick="test(this);">javascript:void(0);</a>
<a href="javascript:;" onclick="test(this);">javascript:;</a>
<a href="####" onclick="test(this);">test</a> //使⽤2个到4个#,见的⼤多是"####",也有使⽤"#all"等其他的
<script>
function test(param) {
var _href = $(param).attr("href") == undefined ? "" : $(param).attr("href");
console.log("href is " + _href);
window.location.href = _href;
}
</script>
</body>
</html>
复制代码
2)点击链接后,响应⽤户⾃定义的点击事件
<a href="javascript:void(0)" onclick="doSomething()">test</a>
<a href="#" onclick="doSomething();return false;">什么问题都解决了,包括浏览器不兼容问题</a> //或者直接使⽤href=""
<a href="#" onclick="alert();urnValue=false;">test</a>
说明:
1.javascript:void(0)这种伪协议,少写的好,如果你看过⼀些web标准的书就知道为什么了。(不懂,原话摘的,暂做记录)
2.链接(href)直接使⽤javascript:void(0)在IE中可能会引起⼀些问题,⽐如:造成gif动画停⽌播放等,
所以,最安全的办法还是使
⽤“####”。为防⽌点击链接后跳转到页⾸,onclick事件return false即可。
3.如果仅仅是想⿏标移过,变成⼿形,可以使⽤
<span onclick="foo()">Click Me!</span>
void是javascript的操作符,意思是:只执⾏表达式,但没有返回值,
void 操作符⽤法格式如下:
javascript:void (expression)
javascript:void expression
为了程序风格良好,建议使⽤第⼆种带上括号的。我们可以使⽤void操作符指定超级链接,如javascript:void(document.form.submit())。表达式会被计算但是不会在当前⽂档处装⼊任何内容,void(0)计算为0,但在JavaScript上没有任何效果,也就是说<a href="javascript:void(0)">的效果同<a href="javascript:void(1)">的效果是⼀样的。关键是只要知道void是javascipt⾃⾝的操作符,它表⽰的
是只执⾏表达式,但没有返回值!另外页⾯会⾃动调回顶端,是因为"#"默认的瞄点位置是top,所以会出现这种情况。
继续解释
我想使⽤过ajax的都常见这样的代码:
<a href="javascript:doTest2();void(0);">here</a>
但这⼉的void(0)究竟是何含义呢?Javascript中void是⼀个操作符,该操作符指定要计算⼀个表达式但是不返回值。
void 操作符⽤法格式如下:
1. javascript:void (expression)
2. javascript:void expression
expression 是⼀个要计算的 Javascript 标准的表达式。表达式外侧的圆括号是选的,但是写上去是⼀个好习惯。 (实现版本 Navigator 3.0 )你以使⽤ void 操作符指定超级链接。表达式会被计算但是不会当前
⽂档处装⼊任何内容。下⾯的代码创建了⼀个超级链接,当⽤户以后不会发⽣任何事。当⽤户链接时,void(0) 计算为 0,但 Javascript 上没有任何效果。
<a href="javascript:void(0)">单此处什么也不会发⽣</a>
下⾯的代码创建了⼀个超级链接,⽤户单时会提交表单。
<a href="javascript:void(document.form.submit())">单此处提交表单</a>
a href=#与 a href=javascript:void(0) 的区别链接的⼏种办法
#包含了⼀个位置信息,默认的锚是#top 也就是⽹页的上端,⽽javascript:void(0)仅仅表⽰⼀个死链接,这就是为什么有的时候页⾯很长浏览链接明明是#却跳动到了页⾸。⽽javascript:void(0) 则不是如此,所以调⽤脚本的时候最好⽤void(0)或者或
等
链接的⼏种办法
1.window.open(’‘url’’)
2.⽤⾃定义函数
复制代码
<script>
function openWin(tag,obj)
{
obj.target="_blank";
obj.href = "Web/Substation/Substation.aspx?stationno="+tag;
obj.click();
}
</script>
复制代码
<a href="javascript:void(0)" onclick="openWin(3,this)">株洲</a>
window.location.href=""
href=”#”,包含了⼀个位置信息.默认的锚是#top,也就是⽹页的上端,当连续快速点击此链接时会导致浏览器巨慢甚⾄崩溃。当然我们⼀般⽤三个 href="###",不过看了这篇⽂章我们以后就可以使⽤javascript:;(⼀个冒号⼀个分号)。
javascript中void是⼀个操作符,该操作符指定要计算⼀个表达式但是不返回值。
javascript:;好些,javascript:void(0);据说某些情况下有浏览器兼容bug。(此点bug我也不知道什么时候能出现,知道的童鞋请指教)。
可以写成javascript:;,qq空间很多都是写成javascript:;
我感觉这两者之间没有什么差别,都是执⾏⼀个空事件。
javascript:;甚⾄少了7个字符,呵呵。
新浪微博写的是javascript:void(0);
我以前⼀直写的是javascript:void(0);但是现在写的都是javascript:;
a href="#"> 点击链接后,页⾯会向上滚到页⾸,# 默认锚点为 #TOP
<a href="javascript:void(0)" onClick="window.open()"> 点击链接后,页⾯不动,只打开链接
<a href="#" onclick="javascript:return false;"> 作⽤同上,不同浏览器会有差异。
点击链接后,不想使页⾯滚到页⾸,就⽤href=“javascript:void(0)”,不要⽤href="#",return false也有类似作⽤
详解href="#"与href="javascript:void(0)"的区别
"#"包含了⼀个位置信息
默认的锚点是#top 也就是⽹页的上端
⽽javascript:void(0) 仅仅表⽰⼀个死链接
这就是为什么有的时候页⾯很长浏览链接明明是#可是跳动到了页⾸
⽽javascript:void(0) 则不是如此
所以调⽤脚本的时候最好⽤void(0)
或者
等打开新窗⼝链接的⼏种办法 1.window.open('url') 2.⽤⾃定义函数
复制代码代码如下:
<script>
function openWin(tag,obj)
{
obj.target="_blank";
obj.href = "Web/Substation/Substation.aspx?stationno="+tag;
obj.click();
}
</script>
<a href="javascript:void(0)" onclick="openWin(3,this)">LINK_TEST</a>
window.location.href=""
如果是个# ,就会出现跳到顶部的情况,个⼈收藏的⼏种解决⽅法:
1:<a href="####"></a>
2:<a href="javascript:void(0)"></a>
3:<a href="javascript:void(null)"></a>
4:<a href="#" onclick="return false"></a>
5:<span ></span>(好像在FF中不能显⽰)
慎⽤JavaScript:void(0)
今天调试CGI的时候,明明CGI程序已经执⾏,并且最后结果也是正确的,但是页⾯就是不刷新。在FireFox2.0下测试,结果却是正常
的,IE6却偏偏不刷新!仔细调查了⼀下,发现cgi页⾯链接的是 <a href=“javaScript:void(0)” OnClick=“XXX_Func();” ….> only a sample ,问题就出在这个void(0)上!让我们先来看看JavaScript中void(0)的含义:
JavaScript中void是⼀个操作符,该操作符指定要计算⼀个表达式但是不返回值。
void 操作符⽤法格式如下:
1. javascript:void (expression_r_r)
2. javascript:void expression_r_r
javascript void 0 是什么意思expression_r_r是⼀个要计算的 JavaScript 标准的表达式。表达式外侧的圆括号是可选的,但是写上去是⼀个好习惯。我们可以使⽤void 操作符指定超级链接。表达式会被计算但是不会在当前⽂档处装⼊任何内容。⾯的代码创建了⼀个超级链接,当⽤户点击以后不会发⽣任何事。当⽤户点击链接时,void(0) 计算为 0,但在 JavaScript 上没有任何效果。
<a href="javascript:void(0)">单击此处什么也不会发⽣</a>
也就是说,要执⾏某些处理,但是不整体刷新页⾯的情况下,可以使⽤void(0),但是在需要对页⾯进⾏refresh的情况下,那就要仔细了。
其实我们可以这样⽤<a href="javascript:void(document.form.submit())">,这句话会进⾏⼀次submit操作。那什么情况下⽤void(0)⽐较多呢,⽆刷新,当然是Ajax了,看⼀下Ajax的web页⾯的话,⼀般都会看到有很多的void(0),:) ,所以在使⽤void(0)之前,最好先想⼀想,这个页⾯是否需要整体刷新。
使⽤javascript的时候,通常我们会通过类似:<a href="#" onclick="javascript:⽅法">提交</a>的⽅式,通过⼀个伪链接来调⽤javascript⽅法.这种⽅法有⼀个问题是:虽然点击该链接的时候不会跳转页⾯.但是滚动条会往上滚,解决的办法是返回⼀个false。
如下所⽰:<a href="#" onclick="javascript:⽅法;return false;">提交</a>
还可以⽤ ###
a href="javascript:void(0)" onclick="javascript:⽅法;return false;"提交
javascript:void(0)就不会向上跳了:)
还有⼀个⽅法是 #this
a href="#this" onclick="javascript:⽅法"
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论