首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >dispatchEvent 'mouseover‘不工作

dispatchEvent 'mouseover‘不工作
EN

Stack Overflow用户
提问于 2015-09-03 16:43:23
回答 1查看 7.7K关注 0票数 3

我有以下代码http://jsfiddle.net/yc7sj3pt/2/

代码语言:javascript
复制
document.getElementById('obj_one').addEventListener('mouseover', function(){
    var e = document.createEvent('HTMLEvents');
    e.initEvent('mouseover', true, false);

    document.getElementById('obj_two').dispatchEvent(e);
    console.log('hover');
}, false);

我试图让#obj_twomouseover on #obj_one时对悬停(因此改变为红色)做出反应,但它不起作用。我做错了什么?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-09-03 16:57:41

根据这个答案,你不能:

用户代理生成的事件,无论是用户交互的结果,还是DOM更改的直接结果,都是由用户代理信任的,用户代理具有通过DocumentEvent.createEvent("Event")方法生成的、使用Event.initEvent()方法修改或通过EventTarget.dispatchEvent()方法发送的脚本生成的事件的权限。可信事件的isTrusted属性的值为true,而不受信任事件的isTrusted属性值为false。 大多数不受信任的事件不应触发默认操作,但单击事件或DOMActivate事件除外。

相反,推荐的方法是在mouseovermouseout事件上添加和删除一个类,这是我在这个小提琴中所做的。

票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/32381243

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档