采用指令的方式来解决这个问题(此处的前端框架以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中实现点击按钮使input显示的同时获取焦点
需求说明:点击搜索按钮出现input框,并自动使input框聚焦。
如图所示:
实现方式1:利用vue的ref
html代码如下:
<input ref="inputVal" class="searchInp" type="text" v-model="searchVal" placeholder="搜索标题或内容..." /> <div v-show="searchBtnFlag" class="searchBtn" @click="searchIn"> <i class="iconfont icon-search1187938easyiconnet"></i> 搜索 </div>
Js代码如下:
searchIn(){ this.searchBtnFlag = !this.searchBtnFlag; this.$nextTick(function () { //DOM 更新了 this.$refs.inputVal.focus() }) },
重点:只需要把需要的操作放在$nextTick内即可。
实现方式2:利用js(原理其实等同于方式1)
<input id="inputVal" class="searchInp" type="text" v-model="searchVal" placeholder="搜索标题或内容..." /> <div v-show="searchBtnFlag" class="searchBtn" @click="searchIn"> <i class="iconfont icon-search1187938easyiconnet"></i> 搜索 </div>
Js代码如下:
searchIn(){ this.searchBtnFlag = !this.searchBtnFlag; this.$nextTick(function () { document.getElementById("inputVal").focus(); }) },
说明:必须在$nextTick内使用方法是因为:dom更新的先后顺序的问题,不是所有的数据改变一定会触发dom的更新,而在修改数据之后立即使用这个方法,可以获取更新后的 dom。
误区:直接使用autofocus
html:
<input v-bind:autofocus="!searchBtnFlag" class="searchInp" type="text" v-model="searchVal" placeholder="搜索标题或内容..." /> <div v-show="searchBtnFlag" class="searchBtn" @click="searchIn"> <i class="iconfont icon-search1187938easyiconnet"></i> 搜索 </div>
js:
searchIn(){ this.searchBtnFlag = !this.searchBtnFlag; this.$nextTick(function () { document.getElementById("inputVal").focus(); }) },
这样的写法只在第一次时起作用,如果点击取消后再次点击搜索按钮则不会再次使input框自动聚焦。
记录一下,以备以后忘了好找。
以上这篇vue 表单输入框不支持focus及blur事件的解决方案就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持站长技术。
很多 SQL 查询都是以 SELECT 开始的。不过,最近我跟别人解释什么是窗口函数,我...
本文实例讲述了JSP程序运行原理、文档结构及简单输入输出。分享给大家供大家参考...
本文实例讲述了YII2框架中behavior行为的理解与使用方法。分享给大家供大家参考...
PHP正则表达式替换实现 是如何的呢?首先向你介绍下 PHP preg_replace,PHP preg...
Plots 是一款图形绘图应用,它可以轻松实现数学公式的可视化。你可以用它来绘制...
尽管微软一直认为自己的任务栏和Mac的Dock有着很多相似之处,但观众们似乎并不认...
防抖和节流到底是啥 函数防抖(debounce) 解释:当持续触发某事件时,一定时间...
此时我们通常能想到的想法是找一个exe程序,把这个问题解决掉。我原来用C#写过这...
CSS背景 背景颜色 背景图片位置 背景色半透明 背景颜色 !DOCTYPE html html lang...
一、使用HTML标签创建表格: 复制代码 代码如下: tableborder="1"width="300" ca...