无法使用 jquery 触发 mousedown 事件 [英] Cannot fire a mousedown event with jquery

查看:30
本文介绍了无法使用 jquery 触发 mousedown 事件的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试使用 jquery 在 http://translate.google.com 中模拟点击事件.为此,我使用以下代码加载了 jquery 文件:

I'm trying to simulate a click event in http://translate.google.com with jquery. For that purpose, I loaded jquery file with this code:

var script = document.createElement("script");
script.src = "http://code.jquery.com/jquery-1.10.1.min.js";
document.body.appendChild(script);

然后我尝试使用选择器模拟对元素的单击,如下所示:

Then I'm trying to simulate a click on an element with a selector, like this:

jQuery(".goog-inline-block.goog-flat-menu-button-caption").trigger("mousedown")

我也试过这个点击事件而不是鼠标按下:

I also tried this click event instead of mousedown:

jQuery(".goog-inline-block.goog-flat-menu-button-caption").trigger("click")

它们都没有给出手动点击div的效果,即打开一个新的div.我附上了所需行为的 ss.

None of them gives the effect of manually clicking to the div, namely opening a new div. I attached the ss of desired behaviour.

jquery 不工作的原因是什么?或者我如何以任何其他方式模拟效果?

What can be the cause for jquery not working? Or how can I simulate the effect in any other ways?

添加 jQuery 似乎是成功的,因为我可以使用 jQuery 方法来选择元素并更改它们的内容等.

Adding jQuery seems to be successful in the sense that I can use jQuery method to select elements and change contents of them etc.

推荐答案

解决方案是创建一个 MouseEvent 并将其分派给元素,如下所示:

The solution was creating a MouseEvent and dispatching it to the element, like this:

var e1 = document.createEvent("MouseEvents");
e1.initMouseEvent("mousedown", true, true, window, 1, 0, 0, 0, 0, false, false, false, false, 0, null);
jQuery('#gt-sl-gms')[0].dispatchEvent(e1)

似乎jQuery的事件机制使用了不同的调度系统,因为它无法触发监听器功能,虽然我没有确认这个信息.

It seems jQuery's event mechanism uses a different dispatching system, since it can not trigger the listener function, though I didn't confirm this info.

这篇关于无法使用 jquery 触发 mousedown 事件的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆