js javascript 模拟点击 超级链接点击 转


转自:http://mo2g.com/view/42/

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

先看下边的代码:

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
< html >
< head >
< meta  charset = "UTF-8" >
< title >磨途歌-A标签测试1</ title >
</ 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
17
18
19
< html >
< head >
< meta  charset = "UTF-8" >
< title >磨途歌-A标签测试2</ title >
</ 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模拟点击该元素即可。


2015年6月15日,根据@bl的补充,我们可以使用更加简单的方式实现同样的功能,代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
< html >
< head >
< meta  charset = "UTF-8" >
< title >磨途歌-A标签测试3</ title >
</ 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($) {
     $("a")[0].click();
});
</ script >

打印$("a")[0],得到的是http://www.mo2g.com,但实际上$("a")[0]是一个object对象,或许说是DOM对象更贴切一些。经过测试发现,其实原生的js就已经实现了类似的点击a标签的功能。原生js写法类似如下:

1
document.getElementsByTagName( "a" )[0].click();

只要获取到A标签的DOM对象,就能使用click()函数激活点击事件了。


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM