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

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

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

先看下边的代码:


1

2

3

4

5

6

7

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模拟点击该元素即可。

时间: 2024-12-29 17:31:49

转:为什么 $("a").click()无效。的相关文章

jQuery-append添加元素click无效

很久没有使用jQuery,做项目的时候遇到一个小问题就是网页加载之后的append的元素是可以执行click事件,网页加载完成之后的,再次append的元素不执行click事件,简单的通过ul模拟一下: <ul class="content"> </ul> <span class="test">测试</span> 三种不同的点击方式,append之后的click无效,通过on执行,注意参数: $(function()

Selenium java中click无效

刚接触selenium,拿wordpress发布文章功能练习,输入文章标题.内容后点发布按钮,element.click()无效,能是找到了元素的,从脚本运行的现象看,感觉只是鼠标指针移动到了元素上,并没有执行click操作,相关代码如下: 尝试过的方法有: 查到一篇关于click()和submit()区别的帖子,说click()只能用于submit按钮,而submit()可以用于form中的所有element,包括form本身.于是修改代码为:form  submit,尝试无效 看到别人说过点

fastclick.js移动端click框架 在安卓手机上部分click无效

解决 fastclick.js 在部分安卓手机上click无效的问题, GitHub地址:  https://github.com/Jaymi66/fastclick fastclick.js 中有检测设备是否支持 touch 的方法, 其实修改 743 744 行加入 else 如果设备支持 则 return false;

Ihone中H5页面用on绑定click无效的解决方法

首先声明本人资质尚浅,本文只用于个人总结.如有错误,欢迎指正.共同提高. ----------------------------------------------------------------------------------- 首先问一句? 为什么移动页面还在用click方法?假如必须用click,且遇到如标题所示bug,下文便是解决之道. 话不多说,当你懂得何时直接绑定click,何时用on绑定时候,理解下文就非常容易. 当用如下方法绑定click事件时, exp: $(docu

解决element-ui 下拉el-dropdown-item添加点击事件@click无效

一.原代码 <DropdownMenu slot="list"> <DropdownItem @click="clickPayButton(payWay)">{{payWay.names}}</DropdownItem> </DropdownMenu> 二.修改代码 <DropdownMenu slot="list"> <DropdownItem @click.native=&qu

jquerymobile,手机端click无效

1.直接把<script>放到html代码后面,不要放到@section里面. 2.使用代理.如下所示: <script type="text/javascript"> $('#nr_abstract a#btnShow').bind('click', function () { $('#nr_abstract').slideUp(); $('#nr_detail').slideDown(); }); $('#nr_detail a#btnHide').bind

C#中的webBrowser空间 连接InvokeMember(&quot;click&quot;) 无效问题

首先要确定获取到了连接对象的前提下 由于设置了取消新窗口打开 private void webBrowser1_NewWindow(object sender, CancelEventArgs e) { e.Cancel=true; } 因此在webbrowser 中的 弹出新窗口的连接都被屏蔽了 显示无效 方法一. //将所有的链接的目标,指向本窗体 foreach (HtmlElement archor in this.webBrowser1.Document.Links) { archor

28.React使用map循环创建对象绑定click无效解决方法

var RechargeBtnEle = React.createClass({ getInitialState: function() { return {id:0}; }, handleClick(item,item1){ console.log(item,item1) }, render(){ let btnArr = this.props.data var newArr = [] for(let i=0;i<btnArr.length;i++){ var item = btnArr[i]

appium+python自动化62-webview元素click失效问题解决

前言 Appium 在切换到 webview 后,正确定位到元素,但是click () 事件后界面无响应,脚本运行正常不会报错. 主要原因是:混合APP 时监听全用的是tap事件,不是click事件 遇到问题 在使用appium,切换到webview后,点击webview里面的某个标签,已经定位到元素了 webview切换成功,并且已经定位到里面的'酒店问题'这个元素 driver.switch_to.context("WEBVIEW_com.yipiao") print(driver