onclick和onblur冲突问题的快速解决方法


Posted in Javascript onApril 28, 2016

新浪首页的搜索框里面有一个使用ajax的下拉框。我们需要实现一个点击下拉框里面的一项,让搜索框里面的值变成这一项,同时下拉框消失的效果,但同时在点击其他地方的时候,这个下拉框也要消失。大致如图:

onclick和onblur冲突问题的快速解决方法

我们同时使用onblur和onclick来使下拉框隐藏,但是更大的问题出现了,这两个功能相冲突,onblur过于强悍,根本没有onclick方法实现的机会,搜索框无法获取点击项的内容。这个就是我们想要解决的onclick和onblur冲突问题。

对应这个问题,这里我们介绍两种解决办法:

1. 使用setTimeout来使onblur时间延期执行,使onclick执行完后再执行onblur。(其中setTimeout的时间设定应该在100ms以上,否则依旧不行)示例代码如下:

<!DOCTYPE html>
<html>
<head lang="en">
  <meta charset="UTF-8">
  <title></title>
  <style>
    *{ margin: 0; padding: 0; list-style: none; }
    form{
      width:500px;
      margin:0 auto;
      position:relative;
      zoom:1;
    }
    form:after{
      clear:both;
      content:"";
      display:block;
    }
    .text{
      float:left;
      border:1px solid #cccccc;
      padding-left:14px;
      width:300px;
      height:34px;
      line-height:34px;
      font-size:14px;
    }
    .button{
      width:50px;
      height:34px;
      border:1px solid #cccccc;
      line-height:34px;
      font-size:14px;
      color:#ffffff;
      background:#ff8400;
    }
    ul{
      position:absolute;
      top:36px;
      left:0;
      width:300px;
      border-right:1px solid #cccccc;
      border-left:1px solid #cccccc;
      background:green;
      display:none;
    }
    li{
      font-size:14px;
      line-height:34px;
      height:34px;
      color:#000000;
      border-bottom:1px solid #cccccc;
    }
    li:hover{
      background:yellow;
      color:red;
      cursor:pointer;
    }
  </style>
  <script>
    window.onload=function(){
      var oText=document.getElementById('text');
      var oUl=document.getElementById('ul');
      var aLi=oUl.getElementsByTagName('li');
      var timer=null;
      oText.onfocus=function(){
        this.value='';
        oUl.style.display='block';
        for(var i=0;i<aLi.length;i++){
          aLi[i].onclick=function(){
            clearTimeout(timer);
            oText.value=this.innerHTML;
            oUl.style.display='none';
          };
        }
      };
      oText.onblur=function(){
        timer=setTimeout(function(){
          oUl.style.display='none';
          if(!oText.value){
            oText.value='请输入关键字';
          }
        },120);
      };
    };
  </script>    
</head>
<body>
<form>
  <input type="text" value="请输入关键字" id="text" class="text"/>
  <input type="button" value="搜索" class="button"/>
  <ul id="ul">
    <li>返回窗口是否已被关闭</li>
    <li>返回窗口的文档显示区的高度</li>
    <li>返回窗口的文档显示区的宽度。</li>
    <li>设置或返回窗口的名称。</li>
    <li>返回窗口的外部高度。</li>
  </ul>
</form>
  
</body>
</html>

2. 使用document.onmousedown来代替onblur实现隐藏下拉框功能

<!DOCTYPE html>
<html>
<head lang="en">
  <meta charset="UTF-8">
  <title></title>
  <style>
    *{ margin: 0; padding: 0; list-style: none; }
    form{
      width:500px;
      margin:0 auto;
      position:relative;
      zoom:1;
    }
    form:after{
      clear:both;
      content:"";
      display:block;
    }
    .text{
      float:left;
      border:1px solid #cccccc;
      padding-left:14px;
      width:300px;
      height:34px;
      line-height:34px;
      font-size:14px;
    }
    .button{
      width:50px;
      height:34px;
      border:1px solid #cccccc;
      line-height:34px;
      font-size:14px;
      color:#ffffff;
      background:#ff8400;
    }
    ul{
      position:absolute;
      top:36px;
      left:0;
      width:300px;
      border-right:1px solid #cccccc;
      border-left:1px solid #cccccc;
      background:green;
      display:none;
    }
    li{
      font-size:14px;
      line-height:34px;
      height:34px;
      color:#000000;
      border-bottom:1px solid #cccccc;
    }
    li:hover{
      background:yellow;
      color:red;
      cursor:pointer;
    }
  </style>
  <script>
    window.onload=function(){
      var oText=document.getElementById('text');
      var oUl=document.getElementById('ul');
      var aLi=oUl.getElementsByTagName('li');
      var timer=null;
      oText.onfocus=function(){
        this.value='';
        oUl.style.display='block';
        for(var i=0;i<aLi.length;i++){
          aLi[i].onclick=function(){
            clearTimeout(timer);
            oText.value=this.innerHTML;
            oUl.style.display='none';
          };
        }
      };
      
      document.onmousedown=function(ev){
        var oEvent=ev||event;
        var target=oEvent.target||oEvent.srcElement;
          if(target.parentNode!==oUl&&target!==oText){
            oUl.style.display='none';
          }
        
      };
      oText.onblur=function(){
        if(!oText.value){
          oText.value='请输入关键字';
        }  
      };
    };
  </script>    
</head>
<body>
<form>
  <input type="text" value="请输入关键字" id="text" class="text"/>
  <input type="button" value="搜索" class="button"/>
  <ul id="ul">
    <li>返回窗口是否已被关闭</li>
    <li>返回窗口的文档显示区的高度</li>
    <li>返回窗口的文档显示区的宽度。</li>
    <li>设置或返回窗口的名称。</li>
    <li>返回窗口的外部高度。</li>
  </ul>
</form>
  
</body>
</html>

以上这篇onclick和onblur冲突问题的快速解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
使用户点击后退按钮使效三行代码
Jul 07 Javascript
jQuery关于导航条背景切换效果实现示例
Sep 04 Javascript
js实现简单的星级选择器提交效果适用于评论等
Oct 18 Javascript
延时加载JavaScript代码提高速度
Dec 27 Javascript
JS动态增删表格行的方法
Mar 03 Javascript
Ext JS框架中日期函数的用法及日期选择控件的实现
May 21 Javascript
Javascript基础_嵌入图像的简单实现
Jun 14 Javascript
JS实现简易的图片拖拽排序实例代码
Jun 09 Javascript
轻量级JS Cookie插件js-cookie的使用方法
Mar 22 Javascript
vue通过cookie获取用户登录信息的思路详解
Oct 30 Javascript
基于React Native 0.52实现轮播图效果
Aug 25 Javascript
详解vue使用$http服务端收不到参数
Apr 19 Javascript
如何使用jquery修改css中带有!important的样式属性
Apr 28 #Javascript
JavaScript String 对象常用方法总结
Apr 28 #Javascript
JavaScript Math 对象常用方法总结
Apr 28 #Javascript
非常漂亮的相册集 使用jquery制作相册集
Apr 28 #Javascript
jQuery事件绑定on()与弹窗实现代码
Apr 28 #Javascript
jquery拖动层效果插件用法实例分析(附demo源码)
Apr 28 #Javascript
JS模仿手机端九宫格登录功能实现代码
Apr 28 #Javascript
You might like
PHP脚本的10个技巧(3)
2006/10/09 PHP
php实现网站插件机制的方法
2009/11/10 PHP
利用php实现禁用IE和火狐的缓存问题
2012/12/03 PHP
Yii核心验证器api详解
2016/11/23 PHP
PHP获取路径和目录的方法总结【必看篇】
2017/03/04 PHP
JQuery验证工具类搜集整理
2013/01/16 Javascript
javascript 获取图片尺寸及放大图片
2013/09/04 Javascript
使用jquery局部刷新(jquery.load)从数据库取出数据
2014/01/22 Javascript
js实现文本框中焦点在最后位置
2014/03/04 Javascript
javascript实现存储hmtl字符串示例
2014/04/25 Javascript
js+csss实现的一个带复选框的下拉框
2014/09/29 Javascript
谈谈JavaScript中function多重理解
2015/08/28 Javascript
Bootstrap精简教程
2015/11/27 Javascript
js+css简单实现网页换肤效果
2015/12/29 Javascript
jQuery 3.0 的变化及使用方法
2016/02/01 Javascript
利用AJAX实现WordPress中的文章列表及评论的分页功能
2016/05/17 Javascript
JavaScript数值千分位格式化的两种简单实现方法
2016/08/01 Javascript
浅谈js中test()函数在正则中的使用
2016/08/19 Javascript
javascript 组合按键事件监听实现代码
2017/02/21 Javascript
jQuery中的deferred对象和extend方法详解
2017/05/08 jQuery
D3.js进阶系列之CSV表格文件的读取详解
2017/06/06 Javascript
JS实现留言板功能[楼层效果展示]
2017/12/27 Javascript
js中apply()和call()的区别与用法实例分析
2018/08/14 Javascript
node微信开发之获取access_token+自定义菜单
2019/03/17 Javascript
AngularJS动态生成select下拉框的方法实例
2019/11/17 Javascript
探索Python3.4中新引入的asyncio模块
2015/04/08 Python
Python中asyncore异步模块的用法及实现httpclient的实例
2016/06/28 Python
在VS Code上搭建Python开发环境的方法
2018/04/06 Python
Python3.6.2调用ffmpeg的方法
2019/01/10 Python
python 应用之Pycharm 新建模板默认添加编码格式-作者-时间等信息【推荐】
2019/06/17 Python
pandas实现DataFrame显示最大行列,不省略显示实例
2019/12/26 Python
Keras实现将两个模型连接到一起
2020/05/23 Python
比利时网上药店: Drogisterij.net
2017/03/17 全球购物
师范类求职信
2014/06/21 职场文书
学校党的群众路线教育实践活动制度建设计划
2014/11/03 职场文书
vue实现同时设置多个倒计时
2021/05/20 Vue.js