在jQuery中,a标签trigger触发click不起作用的原因和解决方法

11 篇文章 0 订阅
8 篇文章 0 订阅

最近在项目中发现,用jq的trigger无法触发a标签的click事件。我的代码如下:

$('a').trigger('click')

 

查阅资料发现:

jquery trigger把(type === "click" && jQuery.nodeName( elem, "a" )) && jQuery.acceptData( elem ) 的事件过滤掉了,不执行其原生点击事件,因此无法触发。$('a').trigger('click'),只是相当于触发了a本身的onclick,而不是像用户点击一样的事件。

解决方法如下:

方法一:

$('a')[0].click();

 

$('a')[0]得到的是原生dom元素,原生a标签的dom用click()可以触发点击事件。

方法二:

在a标签里面加一层span,然后触发span的click事件,通过冒泡触发a标签的点击事件。

<a id="test2" href="javascript:alert('test2')"><span>TEST2</span></a> 

$('#test2').find('span').trigger('click');

参考文章:

https://segmentfault.com/q/1010000003102551

https://stackoverflow.com/questions/5811122/how-to-trigger-a-click-on-a-link-using-jquery

  • 3
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值