javascript MouseEvents问题
高洛峰
高洛峰 2017-04-10 16:17:02
[JavaScript讨论组]
var qqIndex = 0;
var qqBtn = document.querySelectorAll(".myTqBtn.tabBtn0");
var tiggerClick = function(target, eventName){
    var event = document.createEvent("MouseEvents");
    event.initEvent(eventName, !0, !0);
    target.dispatchEvent(event);
};
  1. 第一种方法模拟执行事件

qqBtn[qqIndex] && tiggerClick(qqBtn[qqIndex], "mouseover") && tiggerClick(qqBtn[qqIndex], "mousedown") && tiggerClick(qqBtn[qqIndex], "mouseup") && tiggerClick(qqBtn[qqIndex], "click");
  1. 第二种方法模拟执行事件

qqBtn[qqIndex] && (tiggerClick(qqBtn[qqIndex], "mouseover"), tiggerClick(qqBtn[qqIndex], "mousedown"), tiggerClick(qqBtn[qqIndex], "mouseup"), tiggerClick(qqBtn[qqIndex], "click"));

第一种不能触发click事件,第二种可以触发,为什么用括号括起来然后多个逗号隔开就可以执行了呢?

高洛峰
高洛峰

拥有18年软件开发和IT教学经验。曾任多家上市公司技术总监、架构师、项目经理、高级软件工程师等职务。 网络人气名人讲师,...

全部回复(3)
ringa_lee

因为第一种方法,&& 操作出现 false后面语句就不会执行了

阿神

无返回值的方法返回值是undefined,执行了一个方法后就停了吧

大家讲道理
  1. &&操作具有短路功能

  2. 函数执行后如果没有return语句的话,就返回undefined

  3. qqBtn[qqIndex] && tiggerClick(qqBtn[qqIndex], "mouseover")&&...
    qqBtn[qqIndex] &&undefined执行后整个语句执行就结束了-短路了,只是触发了mouseover事件,click时间不触发了。

  4. (a,b,c,d);a,b,c,d表达式(函数)都会被执行,故click事件也会被触发,但是返回的结果为d的执行结果

热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习
PHP中文网抖音号
发现有趣的

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号