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


Posted in Javascript onJanuary 29, 2015

今天做表格前台导出到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()无效问题的分析了,希望小伙伴们能够喜欢。

Javascript 相关文章推荐
js获取客户端外网ip的简单实例
Nov 21 Javascript
js 通过html()及text()方法获取并设置p标签的显示值
May 14 Javascript
jQuery实现平滑滚动到指定锚点的方法
Mar 20 Javascript
BootStrap的table表头固定tbody滚动的实例代码
Aug 24 Javascript
详解基于vue-cli配置移动端自适应
Jan 13 Javascript
使用vue + less 实现简单换肤功能的示例
Feb 21 Javascript
vue中手机号,邮箱正则验证以及60s发送验证码的实例
Mar 16 Javascript
使用 electron 实现类似新版 QQ 的登录界面效果(阴影、背景动画、窗体3D翻转)
Oct 23 Javascript
express express-session的使用小结
Dec 12 Javascript
ES6 Map结构的应用实例分析
Jun 26 Javascript
基于jsbarcode 生成条形码并将生成的条码保存至本地+源码
Apr 27 Javascript
关于vue 结合原生js 解决echarts resize问题
Jul 26 Javascript
Eclipse配置Javascript开发环境图文教程
Jan 29 #Javascript
js操作滚动条事件实例
Jan 29 #Javascript
jQuery调取jSon数据并展示的方法
Jan 29 #Javascript
jquery通过load获取文件的内容并跳到锚点的方法
Jan 29 #Javascript
浅谈Javascript 数组与字典
Jan 29 #Javascript
javascript 数组操作详解
Jan 29 #Javascript
jQuery实现流动虚线框的方法
Jan 29 #Javascript
You might like
网站用php实现paypal整合方法
2010/11/28 PHP
PHP 获取远程网页内容的代码(fopen,curl已测)
2011/06/06 PHP
PHP输出当前进程所有变量/常量/模块/函数/类的示例
2013/11/07 PHP
PHP字符串比较函数strcmp()和strcasecmp()使用总结
2014/11/19 PHP
Apache服务器下防止图片盗链的办法
2015/07/06 PHP
php获取用户真实IP和防刷机制的实例代码
2018/11/28 PHP
laravel框架模型和数据库基础操作实例详解
2020/01/25 PHP
基于JQuery的动态删除Table表格的行和列的代码
2011/05/12 Javascript
JS简单的图片放大缩小的两种方法
2013/11/11 Javascript
js将控件隐藏及display属性的使用介绍
2013/12/30 Javascript
父页面显示遮罩层弹出半透明状态的dialog
2014/03/04 Javascript
JS实现的用来对比两个用指定分隔符分割的字符串是否相同
2014/09/19 Javascript
JavaScript中数组成员的添加、删除介绍
2014/12/30 Javascript
jQuery实现的Div窗口震动效果实例
2015/08/07 Javascript
解决jQuery使用JSONP时产生的错误
2015/12/02 Javascript
JS中mouseover和mouseout多次触发问题如何解决
2016/06/06 Javascript
jQuery实现的表头固定效果实例【附完整demo源码下载】
2016/08/01 Javascript
详解在Angular项目中添加插件ng-bootstrap
2017/07/04 Javascript
本地搭建微信小程序服务器的实现方法
2017/10/27 Javascript
Bootstrap 3多级下拉菜单实例
2017/11/23 Javascript
layui实现动态和静态分页
2018/04/28 Javascript
angularjs实现对表单输入改变的监控(ng-change和watch两种方式)
2018/08/29 Javascript
在微信小程序中使用图表的方法示例
2019/04/25 Javascript
小程序实现按下录音松开识别语音
2019/11/22 Javascript
[01:23:24]DOTA2-DPC中国联赛 正赛 PSG.LGD vs Elephant BO3 第三场 2月7日
2021/03/11 DOTA
Python numpy 提取矩阵的某一行或某一列的实例
2018/04/03 Python
python3读取csv和xlsx文件的实例
2018/06/22 Python
Python合并2个字典成1个新字典的方法(9种)
2019/12/19 Python
mac安装python3后使用pip和pip3的区别说明
2020/09/01 Python
走近毛泽东观后感
2015/06/04 职场文书
河童之夏观后感
2015/06/11 职场文书
女儿满月酒致辞
2015/07/29 职场文书
校园安全主题班会
2015/08/12 职场文书
班主任工作经验交流会总结
2015/11/02 职场文书
2019年年中工作总结讲话稿模板
2019/03/25 职场文书
Go语言实现Snowflake雪花算法
2021/06/08 Golang