欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

jQuery中$.click()无效问题分析

程序员文章站 2023-11-03 08:13:58
jquery中$.click()无效问题分析,今天做表格前台导出到xls时,想自动触发a的点击。但失败。最后找到这个文件。 我尝试过多次用jquery模拟用户点击a标签的功能,但...

jquery中$.click()无效问题分析,今天做表格前台导出到xls时,想自动触发a的点击。但失败。最后找到这个文件。

我尝试过多次用jquery模拟用户点击a标签的功能,但都没有成功,并且困扰了很久。前段时间的一次发呆,冒出了新的想法,于是就动手进行了测试。

先看下边的代码:

代码如下:


 <html>
<head>磨途歌-a标签测试1<head>
<body>
   <a href="https://blog.mo2g.com">磨途歌<a>
</body>
</html>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"><script>
<script>
jquery(function($) {
  //给所有a标签绑定点击触发事件
  $('a').click(function() {
    alert(1);
  });
  //触发所有a标签的点击事件
  $('a').click();
});
</script>

 

  上边的代码确实已经触发了点击a标签事件,但大家一定也会有疑问,为什么点击了a标签,却不触发a标签的跳转事件?

一开始还以为是做了相应的安全措施,屏蔽了js对a标签的操作,后来发现,并不是这样的,接下来就说说其中的原委。

在开始解释前,我先抛出一个问题。在我们点击“a标签”的时候,究竟是点击了什么才发生的跳转?

1)点击的是“a标签”本身?

2)点击的是“a标签”中显示的文字?

说到这里,大家应该明白了,我们上边的代码已经证实了点击a标签本身,并不会触发跳转到指定链接的事件,就是说,我们平时都是点击的a标签中的文字了?

既然有了头绪,那么就来动手试试。

 

代码如下:


 <html>
<head>磨途歌-a标签测试2<head>
<body>
   <a href="https://www.mo2g.com">磨途歌<a>
</body>
</html>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"><script>
<script>
jquery(function($) {
  var mo2g = '<span id="mo2g">磨延城<span>';
  //给a标签中的文字添加一个能被jquery捕获的元素
  $('a').append(mo2g);
  //模拟点击a标签中的文字
  $('#mo2g').click();
});
</script>

这下效果出来了,事实证明了上述的推断是正确的,所以要想用js模拟点击a标签事件,就得先往a标签中的文字添加能被js捕获的元素,然后再用js模拟点击该元素即可。