Links(HREF元素)的click方法

80酷酷网    80kuku.com

  

关键字: javascript, href, click, method

对于HTML页面上的超链接(HREF),并不是所有的浏览器都支持其click方法。

在IE浏览器(4.0以上版本)中,我们可以使用click方法来模拟一个超链接的点击操作。比如:

document.links[someLinkIndex].click();

click方法首先触发元素的onclick事件;如果onclick事件返回true则继续打开超链接所指向的URL。

但在其他浏览器(比如NS,firefox等)中,并没有提供这样一个方法。不过你可以通过以下的javascript代码为这些浏览器也增加对click方法的支持:

<SCRIPT LANGUAGE="JavaScript1.2">
function linkClick () {
 
var executeAction = true;
 
if (this.onclick) {
    executeAction
= this.onclick({type: 'click'});
  }
 
if (executeAction)
    open (
this.href, this.target ? this.target : '_self');
}

function initLinkClick () {
 
if (document.layers && document.links.length > 0)
    document.links[
0].constructor.prototype.click = linkClick;
}
</SCRIPT>
</HEAD>
<BODY ONLOAD="initLinkClick();">

通过在onload的时候为links元素加载prototype,你就可以在页面实现IE/NS兼容的click方法:

<A HREF= ONCLICK="alert(event.type); return true;">
link1
</A>
|
<A HREF= TARGET="_blank">
link2
</A>
|
<A HREF="http://www.webjx.com" ONCLICK="alert(event.type); return
false;"
>
link3
</A>
|
<BR><FORM><INPUT TYPE="button"  VALUE="link1 click"
   ONCLICK
="document.links[0].click();"><INPUT TYPE="button"  VALUE="link2 click"
   ONCLICK
="document.links[1].click();"><INPUT TYPE="button"  VALUE="link3 click"
   ONCLICK
="document.links[2].click();"></FORM>



分享到
  • 微信分享
  • 新浪微博
  • QQ好友
  • QQ空间
点击: