blur和click事件冲突
一、问题描述
文本框的blur事件和div元素的click事件出现冲突。
在input的blur事件中,我们隐藏div元素。
在div的click事件中,我们清除input的内容,并隐藏自身。
当我们在input中输入内容后,点击div,希望触发div的click事件,清除input的内容,并隐藏自身。不料先触发了input的blur事件,隐藏了div元素,导致无法完成div的click事件。
二、问题分析
出现上述问题,让人不得不去探索事件执行顺序。
1、在一个input文本框中绑定如下事件,测试执行顺序
onmouseover,onmouseenter,(onmousemove) onmousedown,onfocus,(onmousemove) onmouseup,onclick,(onmousemove) onkeydown,onkeypress,oninput,onkeyup,(onmousemove) onmouseout,onmouseleave,onchange,onblur
2、在一个文本框和div标签中都绑定事件,测试执行顺序
【input】 onmouseover,onmouseenter,(onmousemove) onmousedown,onfocus,(onmousemove) onmouseup,onclick,(onmousemove) onkeydown,onkeypress,oninput,onkeyup,(onmousemove) onmouseout,onmouseleave, 【div】 onmouseover,onmouseenter,(onmousemove) onmousedown 【input】 onchange,onblur 【div】 (onmousemove) onmouseup,onclick,(onmousemove) onmouseout,onmouseleave
3、mouseover和mouseenter的区别
不论鼠标指针穿过被选元素或其子元素,都会触发mouseover事件。
只有在鼠标指针穿过被选元素时,才会触发mouseenter事件。
4、mouseout和mouseleave的区别
mouseout事件会冒泡,子节点的mouseout事件会冒泡到父节点,进而触发父节点的mouseout事件。
mouseleave事件就没有这种效果,所以离开子节点时,不会触发父节点的监听函数。
三、解决方案
1、为blur添加延迟
dom_input.addEventListener('blur',function(e){
setTimeout(function () {
dom_div.style.display = "none";
}, 200);
},true);
让div延时隐藏,可以解决div无法被点击的问题。但设置多久的延时是一个难以两全的问题,时间太短不能保证click事件的100%触发,时间太长则会造成卡顿的感觉,影响用户体验。因此,设置延时并不是该问题的最佳解决方案。
2、blur事件的动态绑定
//鼠标进入div区域,取消文本框的blur事件绑定
var fn = function(e){
dom_div.style.display = "none";
}
dom_div.addEventListener('mouseenter',function(e){
dom_input.removeEventListener("blur", fn, false);
},true);
//鼠标移出div区域,为文本框绑定blur事件
dom_div.addEventListener('mouseleave',function(e){
dom_input.addEventListener("blur", fn, true);
},true);
3、mousedown代替click
dom_input.addEventListener('blur',function(e){
dom_div.style.display = "none";
},true);
dom_div.addEventListener('mousedown',function(e){
dom_input.value ='';
dom_div.style.display = "none";
},true);
blur和click事件冲突的更多相关文章
- 下拉选择的blur和click事件冲突了
当写个下拉选择框时我们希望当input失去焦点时,下拉框消失,或者当选择下拉框中的内容的同时将内容填入input并且使下拉框消失. 这时候我们会想到blur和click,单独使用的时候是没有问题的,但 ...
- jquery href属性和click事件冲突
a标签的定义如下: <a href="javascript:void(0);">test</a> jquery中的click事件: $("a&qu ...
- js(jquery)解决input元素的blur事件和其他非表单元素的click事件冲突的方法
HTML结构:很简单,就一个input,一个div,能说明问题就OK了: <input type="text" value="默认值"><br ...
- onblur事件和click事件冲突
在js中onblur事件的优先级click事件,所以同一个元素上绑定两个事件的时候,onblur事件会冲掉click事件. 解决方案:将click事件改成mousedown事件
- 移动端touch拖动事件和click事件冲突问题解决
通过一个悬浮球交互功能的案例来阐述问题,以及解决办法. 实现效果 类似微信里的悬浮窗效果,苹果手机的悬浮球功能效果 可以点击拖动,然后吸附在窗口边缘 点击悬浮球,可以跳转界面,或者更改悬浮球的形态 准 ...
- blur和click事件的先后顺序问题
这两个同时用会有冲突.懒得翻译了,需要的自己看哈. 以下摘自stackoverflow. I have an input field, where I try to make autocomplete ...
- Vue--el-menu 的自动跳转功能与自己的click事件冲突
一\先看elementUI说明 项目实际 此时点击活导航时以 index 作为 path 进行路由跳转 那么此时不要onclik事件了 如果此时有在有click 就
- HTML A标签 href click事件冲突
转自:https://blog.csdn.net/xinglu/article/details/45199337
- 快速解决js开发下拉框中blur与click冲突
在开发中我们会经常遇到blur和click冲突的情况.下面叙述了开发中常遇到的"下拉框"的问题,并提供了两种解决方案. 一.blur和click事件简述 blur事件:当元素失去焦 ...
随机推荐
- 用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建二:配置MyBatis 并测试(2 配置spring-dao和测试)
用IntelliJ IDEA 开发Spring+SpringMVC+Mybatis框架 分步搭建二:配置MyBatis 并测试(1 搭建目录环境和依赖) 四:在\resources\spring 下面 ...
- Python多进程与单进程效率对比
运行环境:Python3 in win10 先生成200个测试文件 # generate.py i = 0 while i < 200: o = open("test\\" ...
- linux系统无法启动或无法登入
修改root权限: https://blog.csdn.net/houjue2298/article/details/78539827 修改密码: https://www.cnblogs.com/we ...
- 针对监控摄像机(海康、大华等)录像 .h264 文件的流媒体播放设计
监控摄像机(海康.大华等)内部带的录像功能一般录制的是h264文件,这种文件格式简单的把每一帧h264字节数据保存到文件里. 实际使用中,可能需要对特定录像进行反复检测,以训练.改进视频检测算法的准确 ...
- JavaScript 执行环境、作用域、内存管理及垃圾回收机制
前言 JavaScript具有自动垃圾收集机制,也就是说,执行环境会负责管理代码执行过程中使用的内存. [原理]找出那些不再继续使用的变量,然后释放其占用的内存.为此,垃圾收集器会按照固定的时间间隔( ...
- Excel 当前行高亮
格式-条件格式-条件(公式)- =ROW()=CELL("row") 再选颜色...即可.
- shell1
shebang = sharp-bang = #! 1.echo $PATH export PATH="$PATH:/home/user/bin" PREPEND prepend( ...
- 记事本 HTML
又学了一遍HTML,感觉轻松了好多,个人感觉HTML和画画差不多,只要有了想法,画出来其实并不难. 头部信息<head> 头部信息并不是给我们看的,而是给浏览器看的,当浏览器看到之后,才好 ...
- Ansible------常用功能
local_action Ansible 默认只会对控制机器执行操作,但如果在这个过程中需要在 Ansible 本机执行操作就需要使用到local_action become:True Ansible ...
- Django 实现list页面检索
在list.html写入from表单 在views渲染list方法写入,从前台获取的searchtitle根据name实现检索