Vue表单输入框不支持focus及blur怎么办,如何处理
Admin 2022-06-02 群英技术资讯 1272 次浏览
这篇文章给大家分享的是“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中实现点击按钮使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框自动聚焦。
记录一下,以备以后忘了好找。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章给大家分享的是JavaScript中位运算符。小编觉得挺实用的,因此分享给大家做个参考。JavaScript中的有7种位运算符,文中的示例代码介绍得很详细,有需要的朋友可以参考,接下来我们一起来看看它们的使用。
今天给大家分享的是JS如何提高开发效率的内容,其实有很多JavaScript技巧可以帮助我们提高开发的效率,接下来小编就给大家分享一下比较实用的技巧,感兴趣的朋友就继续往下看吧。
Vue Router是Vue.js (opens new window)官方的路由管理器,它和 Vue.js 的核心深度集成,让构建单页面应用变得易如反掌,这篇文章主要给大家介绍了关于vue3使用vue-router的相关资料,需要的朋友可以参考下
这篇文章主要为大家详细介绍了js实现音乐播放器,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
这篇文章主要为大家详细介绍了JavaScript实现标签页切换效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008