我尝试过多次用jQuery模拟用户点击a标签的功能,但都没有成功,并且困扰了很久。后来的一次发呆,冒出了新的想法,于是就动手进行了测试。
我尝试过多次用jQuery模拟用户点击a标签的功能,但都没有成功,并且困扰了很久。前段时间的一次发呆,冒出了新的想法,于是就动手进行了测试。
先看下边的代码:
< 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标签中的文字了?
既然有了头绪,那么就来动手试试。
< 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模拟点击该元素即可。