zoukankan      html  css  js  c++  java
  • input中blur失去焦点事件与点击事件冲突时如何解决

    方法一

    使用setTimeout

    $(function(){
      $(".cy-name-input input").on({
        focus:function() {
          $(".cy-close").css('display','block');
        },
        blur:function() {
          setTimeout(function(){
            $(".cy-close").css('display','none');
          },0)
        }
      })
      $(".cy-close").click(function(){
        $(".cy-name-input input").val('');
      })
    })
    方法二
    只要给按钮设置 mousedown 事件,并在其中 event.preventDefault() 就可以了
    // html
    <input type="text" autofocus="autofocus">
    <button>点击我文本输入框不会失去焦点</button>
    
    // javascript
    var btn = document.querySelector('button')
    btn.onmousedown = function(event) {event.preventDefault()}
    想要点击按钮,触发按钮的 click 事件,但又不想触发 input 的 blur 事件。 这里面的问题就在于,当我们点击按钮的时候,文本框失焦,这是浏览器的默认事件。当你点击按钮的时候,会触发按钮的 mousedown 事件,mousedown 事件的默认行为是使除了你点击的对象之外的有焦点的对象失去焦点。所以只要在 mousedown 事件中阻止默认事件发生就可以了!
  • 相关阅读:
    知足老师对于脚跟酸经验
    《伤寒论》理论的临床应用--朱良春
    大便秘结案
    胃脘不适论治
    杏林集叶效方
    腰痛案(知足老师论辩证之重要性)
    小儿外感治疗误区
    小儿外感咳喘案
    漫谈凭脉用药--何少奇
    咽部不适案
  • 原文地址:https://www.cnblogs.com/web-record/p/10075375.html
Copyright © 2011-2022 走看看