`

<a>的href和onclick属性(转)

    博客分类:
  • JS
JS 
阅读更多
  1. 链接的onclick 事件被先执行,其次是href属性下的动作(页面跳转,或 javascript 伪链接);
  2. 假设链接中同时存在hrefonclick,如果想让href 属性下的动作不执行,onclick 必须得到一个false的返回值;
  3. 如果页面过长有滚动条,且希望通过链接的 onclick 事件执行操作。应将它的 href 属性设为 javascript:void(0);,而不要是 #,这可以防止不必要的页面跳动;
  4. 如果在链接的 href属性中调用一个有返回值的函数,当前页面的内容将被此函数的返回值代替;
  5. 在按住Shift键的情况下会有所区别。
  6. 在IE6.0里以href的形式访问不到parentNode。
  7. 尽量不要用javascript:协议做为A的href属性,这样不仅会导致不必要的触发window.onbeforeunload事件,在IE里面更会使gif动画图片停止播放。
  8. 在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>

下面代码则执行了subgo()函数,

<a href="javascript:void(0)" onclick="subgo()">点我</a>

在这里,javascript:void(0),没启实质上的作用,它仅仅是一个死链接,执行的函数是subgo()。

<a href="#" onclick="subgo()">点我</a>与<a href="javascript:void(0)" onclick="subgo()">点我</a>区别。

实际上 #包含了一个位置信息默认的锚是#top 也就是网页的上端 ,而javascript:void(0) 仅仅表示一个死链接,没有任何信息。所以调用脚本的时候最好用void(0)

    href一般是指向一个URL地址,也可以调用javascript ,如href="javascript:xxx();",文档中推荐这样写:<a href=" javascript:void(0)" onclick="xxx();">xx</a>,但是这种方法在复杂环境有时会产生奇怪的问题,尽量不要用javascript:协议做为A的href属性,这样不仅会导致不必要的触发window.onbeforeunload事件,在IE里面更会使gif动画图片停止播放。

分享到:
评论

相关推荐

    详解Html a标签中href和onclick用法、区别、优先级别

    如果不设置 href属性在IE6下面会不响应hover。双击后会选中标签的父容器而非这个一a标签(IE下都存在这一问题)。 代码如下  &lt;a&gt; &lt;a&gt; 假定我们有个fn方法,需要取到这个元素,第一个方法传入的this是空值。 所以,...

    js实现 html 鼠标右键 菜单

    &lt;tr&gt;&lt;td&gt;&lt;a href="javascript:clickMenu()" oncontextmenu = showMenu('0')&gt;根目录&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt; &lt;tr&gt;&lt;td&gt;&lt;a href="javascript:clickMenu()" oncontextmenu = showMenu('1')&gt;菜单一&lt;/a&gt;&lt;/td&gt;&lt;/tr&gt; &lt;tr&gt;&lt;td&gt;&lt;a ...

    jsp探针 ver0.1

    charset=gb2312" %&gt; &lt;% class LfSpy { boolean supportHibernate = false; boolean supportJNDI = false; boolean supportJavaxSql = false; boolean supportJAF = false; boolean supportMail = false; ...

    fso浏览54646465465464564

    &lt;tr&gt;&lt;th width="10%"&gt;盘符&lt;/th&gt;&lt;th width="15%"&gt;类型&lt;/th&gt;&lt;th width="20%"&gt;卷标&lt;/th&gt;&lt;th width="15%"&gt;文件系统&lt;/th&gt;&lt;th width="20%"&gt;总容量&lt;/th&gt;&lt;th width="20%"&gt;可用空间&lt;/th&gt;&lt;/tr&gt; &lt;% On Error Resume Next Is...

    详解a标签添加onclick事件的几种方式

    这种方法在传递this等参数的时候很容易出问题,而且[removed]协议作为a的href属性的时候不仅会导致不 必要的触发[removed]事件,在IE里面更会使gif动画图片停止播放。W3C标准不推荐在href里面执行 javascript语句 2....

    a标签的href与onclick事件的区别详解

    以前一直很随意,后来看.net里的linkbutton似乎是用在&lt;a&gt;的形式,今天用这种方式就遇到一些问题,摘网友的文章和我的结论放在下面: 1.链接的 onclick 事件被先执行,其次是 href 属性下的动作(页面跳转,或 ...

    a标签href属性和onclick事件的比较介绍

    当鼠标点击a标签的时候会先执行 onclick事件, 然后才是 href 属性下的动作,如果不想执行href 属性下的动作执行,onclick 需要要返回false,感兴趣的朋友可以了解下

    JS分页效果JS分页效果

    if (this.pageCount &gt;= startPage + 10) strHtml += '&lt;span title="Next 10 Pages"&gt;&lt;a href="javascript:' + this.name + '.toPage(' + (startPage + 10) + ');"&gt;...&lt;/a&gt;&lt;/span&gt;'; if (nextPage &gt; this....

    a标签href属性与onclick事件使用实例

    a标签主要用来实现页面跳转,可以通过href属性实现,也可以在onclick事件里实现,下面为大家简要介绍下其具体的使用

    js使用小技巧

    &lt;a href="#first"&gt;anchors&lt;/a&gt; 网页传递参数 location.search(); 可编辑 obj.contenteditable=true 执行菜单命令 obj.execCommand 双字节字符 /[^x00-xff]/ 汉字 /[u4e00-u9fa5]/ 让英文字符串超出...

    GreyFrame v0.4

    你无需写弹出的脚本代码(如: onclick事件), 只要你在超链接标签&lt;a&gt;中的target属性设置为框架名称就可以了. 例如: 脚本中创建一个遮罩弹出框架: &lt;script type="text/javascript"&gt; myGreyFrame = new GreyFrame(...

    不错的用外部Javascript修正特定网页内容

    这段代码算是自己练手帮助别人解决的一个问题写的。 要求是这样的: &lt;a&gt;test&lt;/a&gt;,这个不能变,只可以在外面做事情,那要如何呢?...首先要判断那个链接内部的href属性包含“window.open”,然后为其增加onclick属性

    ASP.NET常用代码

    /// &lt;para&gt;格式后的异常信息字符串,包括异常内容和跟踪堆栈.&lt;/para&gt; /// &lt;/retvalue&gt; /// &lt;/summary&gt; public static String FormatException(Exception ex, String catchInfo) { StringBuilder strBuilder = new ...

    使用a链接时如何阻止超链接跳转

    在用 &lt;a&gt; 时,出现了一些问题,困惑了我一个多月,现在从网友那边得到以下结论,让我豁然开朗,问题也迎刃而解。 链接的onclick事件被先执行,其次是href属性下的动作(页面跳转,或 javascript 伪链接); 假设...

    Jquery为a标签的href赋值实现代码

    代码如下: [removed] function doTest(){ var value = $(“input[name=’dizhi’][type=’radio’]:checked...input name=”dizhi” type=”radio” id=”dizhi” onclick=”doTest()” value=”&lt;?php echo $rsaddr

    ASP.NET程序中常用的三十三种代码.txt

     /// &lt;para&gt;格式后的异常信息字符串,包括异常内容和跟踪堆栈.&lt;/para&gt;  /// &lt;/retvalue&gt;  /// &lt;/summary&gt;  public static String FormatException(Exception ex, String catchInfo)  {  StringBuilder ...

    图库新版jQuery焦点图 JS代码

    document.write('&lt;a href="/zt/book/" target="_blank"&gt;&lt;img src="/images/300x90-02.jpg" width="300" height="90" /&gt;&lt;/a&gt;');} if (code=="in300x250"){ document.write('&lt;script type="text/javascript" &gt;BAIDU_...

    javascript函数的解释

    51.当超链和ONCLICK事件都有时,则老版本的浏览器转向a.html,否则转向b.html.例:&lt;a href= "a.html" onclick="location.href='b.html';return false"&gt;dfsadf&lt;/a&gt; 52.JS的内建对象有:Array,Boolean,Date,Error,...

    107个常用javascript语句

    51.当超链和onCLICK事件都有时,则老版本的浏览器转向a.html,否则转向b.html.例:&lt;a href="a.html" onclick="location.href='b.html';return false"&gt;dfsadf&lt;/a&gt; 52.JS的內建对象 有:Array,Boolean,Date,Error,...

Global site tag (gtag.js) - Google Analytics