转:为何 $("a").click()无效。

今天作表格前台导出到xls时,想自动触发a的点击。但失败。最后找到这个文件。html

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

先看下边的代码:ajax

1api

2浏览器

3安全

4app

5测试

6google

7spa

8

9

10

11

12

13

14

15

16

17

<html>

<head>磨途歌-A标签测试1<head>

<body>

   <a href="http://blog.mo2g.com">磨途歌<a>

</body>

</html>

<script src="http://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标签中的文字了?

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

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

<html>

<head>磨途歌-A标签测试2<head>

<body>

   <a href="http://www.mo2g.com">磨途歌<a>

</body>

</html>

<script src="http://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模拟点击该元素便可。

相关文章
相关标签/搜索