我的编程空间,编程开发者的网络收藏夹
学习永远不晚

vue中监听input框获取焦点及失去焦点的问题

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

vue中监听input框获取焦点及失去焦点的问题

一、背景

博主之前在用vue的获取焦点,失去焦点的时候,出现了@blur和@focus无效的情况。当时百思不得其解。今天又在写vue页面的时候,突然@blur和@focus又好用了。emmmm,看来这部分值得一战。

二、首先是正宗的监听事件的写法

1、html代码

//这是html的输入框。定义了一个获取焦点,失去焦点的方法
 <input placeholder="请输入企业名称" @blur="animateWidth('company_name','blur')" @focus="animateWidth('company_name','focus')" >

2、JS部分

   // 失去焦点和得到焦点的验证方法,name为要验证的字段名,type为blur或focus
    animateWidth(name, type) {
      if (name == "company_name") {
        if (type == "blur") {
          this.companyName.animate = false;
        } else {
          this.companyName.animate = true;
          return;
        }
        if (this.companyName.companyName.trim().length == 0) {
            this.companyName.valid = false;
            this.companyName.message = "请输入企业名称";
            return false;
        }else{
             this.companyName.valid = true;
            return true;
        }  
      } 
    },

这个方法算是通用的方法,大家在html里面根据自己的需求传不同的值即可。

三、为什么上次监听焦点事件失败呢

1、不好用的原因

博主又去看最初自己用@blur和@focus失败的代码,发现:

  <i-input class="wallet-password-1" size="large"  v-model="counts" refs = "counts" placeholder="0" type="number">
                </i-input>

上次用的html部分是借用i-view框架的,也就是说,我们在使用vue的一些方法的时候,可能会和ui框架定义的方法冲突,这部分参考资料 

了解原因之后,我们就知道了,使用vue自带的@blur和@focus是没问题的,如果在你的代码中不起作用,那只能证明一件事,那就是你的UI框架自己定义的有获取焦点失去焦点的方法。建议大家使用UI框架之前,先去官方文档看看,这样会好很多。

2、新增指令的方法

之前百度的时候,看到很多人都说可以通过新增指令来自定义获取焦点失去焦点的方法,具体的可以参考文末内容补充介绍。

补充介绍:vue框架中的表单输入框不支持focus以及blur事件的解决方案

采用指令的方式来解决这个问题(此处的前端框架以mint-ui为例):

1.html引用: v-mtfocus

2.在实例中添加指令

directives: {
    'mtfocus' (el, binding, vnode) {
      let mtinput = el.querySelector('input')
      mtinput.onfocus = function () {
       ...//如果要对节点的数据进行更改,且更改要映射到页面上,则更改可在vnode.context上进行,这样,改完之后,改变就会映射到页面
      }
      mtinput.onblur = function () {
        ...//同上理
      }
    }
  }

出现这个问题,说到底还是自己对vue不熟练造成的,姑且记录一下吧。

到此这篇关于vue中监听input框获取焦点,失去焦点的问题的文章就介绍到这了,更多相关vue input框失去焦点内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

vue中监听input框获取焦点及失去焦点的问题

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Vue使用el-input自动获取焦点和二次获取焦点问题及解决

这篇文章主要介绍了Vue使用el-input自动获取焦点和二次获取焦点问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-12-08

vue中的input框点击后不聚焦问题怎么解决

今天小编给大家分享一下vue中的input框点击后不聚焦问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。input
2023-06-30

Vue3.0中ElementPlus<input输入框自动获取焦点>问题怎么解决

这篇文章主要介绍“Vue3.0中ElementPlus问题怎么解决”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Vue3.0中ElementPlus
2023-07-05

Vue中的@blur事件当元素失去焦点时所触发的事件问题

这篇文章主要介绍了Vue中的@blur事件当元素失去焦点时所触发的事件问题,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
2022-11-13

编程热搜

目录