JQuery,JavaScript创建链接并模拟点击

用JQuery创建一个a标签,在设定a标签的属性后,再用JQuery模拟点击一下该链接。我写了一段代码但不知为何不能触发点击。代码如下:

 

<html>  
<head>  
<script type="text/javascript" src="jquery-1.7.js"></script>  
<script type="text/javascript">  
function clickMe() {  
    var $aa = $('<a></a>');  
    $aa.attr('href','www.sohu.com');  
    $aa.attr('target','_blank');  
    alert($aa.attr('href'));    //$aa.click();  
    $aa.trigger('click');  
}  
</script>  
</head>  
<body>  
<input type="button" id="btn" value="Click Btton" οnclick="clickMe()"/>  
</body>  
</html> 

原来我以为可以直接 用click()函数,结果不行,然后我又改成了trigger()函数,还是不行。

 

有人提议改成javascript的click而不是JQuery的click,代码如下:

 

<html>  
<head>  
<script type="text/javascript" src="jquery-1.6.4.js"></script>  
<script type="text/javascript">  
function clickMe() {  
    var $aa = $('<a>');  
    $aa.html('sohu');  
    $('#btn').parent().append($aa);  
    $aa.attr('href','http://www.sohu.com');  
    $aa.attr('target','_blank');  
    $aa.get(0).click();  
}  
</script>  
</head>  
<body>  
<input type="button" id="btn" value="Click Btton" οnclick="clickMe()"/>  
</body>  
</html>

这样做确实可以,但是有一个问题,在IE和FF下,这段代码好使;但是在chrome下,点击事件失效。

有人专门做了些实验,在“JavaScript模拟用户单击事件”做了说明。Chrome确实存在这个问题。

 

因此把代码改成如下:

 

<html>  
<head>  
<script type="text/javascript" src="jquery-1.6.4.js"></script>  
<script type="text/javascript">  
function clickMe() {  
    var $aa = $('<a>');  
    $aa.html('sohu');  
    $('#btn').parent().append($aa);  
    $aa.attr('href','http://www.sohu.com');  
    $aa.attr('target','_blank');  

    if($.browser.msie || $.browser.mozilla) {
        $aa.get(0).click();  
    }else {
    	window.open($aa.attr('href'), $aa.attr('target'));
    }
}  
</script>  
</head>  
<body>  
<input type="button" id="btn" value="Click Btton" οnclick="clickMe()"/>  
</body>  
</html> 

虽然window.open()方法会可能被浏览器屏蔽,不过这是目前我找到的相对较好的做法。

 

 

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值