javascript - 如何完美模拟一个鼠标指针移进且停留一秒的事件?
高洛峰
高洛峰 2017-04-10 16:06:26
[JavaScript讨论组]

开始我想用CustomEvent。
但用了发现这个API并没有起什么用。
于是我这样写了:

obj[i].addEventListener("mouseover",hoverListener ,false);
        function hoverListener(event) { 
            event.target.addEventListener("mouseout", function() {
                clearTimeout(t);
            },false);
            var t = setTimeout(function(){event.target.click();},1000);
        }

这样写有个问题,就是每次mouseover都会注册一个mouseout的侦听器,且无法覆盖,应为函数在mouseover的处理函数中定义的。
后来想过用on属性,但既然要求完美,on属性只此一个,不宜于扩展。

所以最终问题有这几个:

  1. 事件处理函数在后面声明,这个函数体内任何位置都可以用,为什么火狐报错?

  2. 如何完美注册一个鼠标指针移进且停留一秒的事件处理程序,而且不破坏全局对象

用例地址:codepen.io/mantou132/pen/eprXZK

高洛峰
高洛峰

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

全部回复(1)
ringa_lee
function hoverForOneMinute(ele,handler,useCapture){
       var hoverStart;
       var isHoverEnd=false;
       var eleId=ele.addEventListener("mouseover",function(){
           hoverStart=new Date().getTime();
           isHoverEnd=false;
           sleep(1000);
           
           if(!isHoverEnd){
               handler();
           }
       },useCapture);
       
       ele.addEventListener("mouseout",function(){
           isHoverEnd=true;
       },userCapture);
}

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

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