jQuery中$.click()无效问题分析
2018-10-12 14:02
746 查看
今天做表格前台导出到xls时,想自动触发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模拟点击该元素即可。
以上就是本文讲诉的相关jQuery中$("a").click()无效问题的分析了,希望小伙伴们能够喜欢。
您可能感兴趣的文章:
- jquery单选框radio绑定click事件实现方法
- jquery bind(click)传参让列表中每行绑定一个事件
- 使用jQuery的attr方法来修改onclick值
- jquery 为a标签绑定click事件示例代码
- jquery trigger伪造a标签的click事件取代window.open方法
- JQuery给元素绑定click事件多次执行的解决方法
- jQuery防止click双击多次提交及传递动态函数或多参数
- jQuery focus和blur事件的应用详解
- jquery focus(fn),blur(fn)方法实例代码
- jQuery解决input元素的blur事件和其他非表单元素的click事件冲突问题
相关文章推荐
- jQuery中$.click()无效问题分析
- jQuery中$.click()无效问题分析
- jQuery基于toggle实现click触发DIV的显示与隐藏问题分析
- 手机浏览器下better-scroll中click事件,链接无效的问题
- [转载]解决ListView的OnItemClickListener无效问题
- 解决ListView的ItemView中带有Button时,OnItemClick无效的问题
- ListView setOnItemClickListener无效原因分析
- ListView setOnItemClickListener无效原因分析
- Ubuntu在/etc/profile中配置好了Java环境,运行Java子命令无效问题(~/.bashrc等文件分析)
- jQuery应用load()方法后js失效的问题分析与解决
- x2签名长度限制无效的问题分析及改进方法
- jQuery中checkbox的click方法中判断checked属性问题
- jQuery页面刷新(局部、全部)问题分析
- jquery.validate[.unobtrusive]和Bootstrap实现tooltip错误提示问题分析
- jQuery使用on()绑定动态生成元素的事件无效的问题
- 瀑布流 或者动态加载 click点击无效的问题
- ListView.setOnItemClickListener无效问题的解决
- 使用jquery控制checkbox勾选无效问题
- 解决火狐浏览器发送jquery的ajax请求无效的问题
- selenium click无效问题