@ZEAL Blog·厉
We stand alone,
TOGETHER.

Links(HREF元素)的click方法

Posted by zeal on 2005-06-02 13:26 , 1716 characters |  + 0 - 1   English
转载请保留本行原始出处声明信息 : http://www.zeali.net/entry/76 MaDe1nZEAL
标签 ( WebDev ):  ,  ,  , 
对于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=http://www.zeali.net/ ONCLICK="alert(event.type); return true;">
link1
</A>
|
<A HREF=http://www.newmenbase.net/ TARGET="_blank">
link2
</A>
|
<A HREF="http://www.faqts.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>

原文出处:http://www.faqts.com/knowledge_base/view.phtml/aid/1122

Last Modified on 2005-06-16 16:38
1 条评论:
- flash2005-06-06 18:03
原来如此。怪不得在firefox下我的代码不起作用。
Since 2005.04.27  梦想 就像鸡蛋 要么孵化 要么臭掉RSS Feed (Entries) | Back To Home | @ZEAL | 沪ICP备05024379号