Vue输入框状态切换&自动获取输入框焦点的实现方法
场景:
点击button
按钮展示输入框,并自动获取对话框焦点,失去焦点时展示button
按钮
实现:
1.点击button
按钮展示输入框,失去焦点时展示button
按钮
- 在data中定义
visibility
,确定输入框的展示状态,默认为false
- 定义
changeVisibility
方法,并给button
绑定点击事件@click="changeVisibility"
,实现点击按钮展示输入框,给输入框绑定失去焦点事件@blur="changeVisibility"
- 定义
input
和button
元素,绑定条件渲染指令v-if
,当visibility
为false
时展示按钮,反之展示输入框
代码实现:
<template> <div> <label for="input"> <input type="text" ref="inputRef" v-if="visibility" @blur="changeVisibility"> <button @click="changeVisibility" v-else>展示文本框</button> </label> </div> </template> <script> export default { data() { return { visibility: false } }, methods: { changeVisibility() { this.visibility = !this.visibility // 切换 visibility,控制输入框的显示状态 } } } </script>
2.自动获取对话框焦点
文本框的焦点可以通过.focus()
获取,因此我们可以通过this.$refs.inputRef.focus()
获取到显示的输入框的焦点(inputRef
是创建文本框时添加的ref
引用)。但是方法定义在组件渲染之前,因此直接在方法中添加会导致控制台报错:Error in v-on handler: "TypeError: Cannot read properties of undefined (reading 'focus')"
。这是由于浏览器执行到this.$refs.inputRef.focus()
时,input
元素还没有被渲染到页面上,此时DOM中还不存在指定的input
元素。为了避免这种情况,可以使用以下三种方法推迟焦点的获取
- 设置定时器, 推迟焦点的获取
setTimeout(()=> { this.$refs.inputRef.focus() },0)
设置一个0ms的定时器,当浏览器执行到定时器时,会将定时器内部的函数放入延迟队列中,当定时器的等待事件结束后,会将函数放入消息队列的末尾,消息队列的执行按照先进先出原则,当前面的任务执行完成后,浏览器会自动执行this.$refs.inputRef.focus()
实现焦点的获取
- 使用
$nextTick
方法, 将获取焦点推迟到下一个 DOM 更新周期
this.$nextTick(()=> { this.$refs.inputRef.focus() })
组件的$nextTick(cb)
方法,会把 cb 回调推迟到下一个 DOM 更新周期之后执行。
通俗的理解是:等组件的 DOM 更新完成之后,再执行 cb 回调函数。从而能保证 cb 回调函数可以操作到最新的 DOM 元素。
将获取焦点放到updated
生命周期中执行(不推荐)
使用这个方法时,需要加上if
判断,否则每一次this.visibility
发生变化时,都会执行一次更新,增加服务器的负担
updated() { if (this.visibility){ this.$refs.inputRef.focus() } }
当组件处于updated
时,页面已经根据最新的数据渲染完成了,此时我们执行this.$refs.inputRef.focus()
就可以正常获取输入框的焦点
到此这篇关于Vue输入框状态切换&自动获取输入框焦点の实现的文章就介绍到这了,更多相关Vue动获取输入框焦点内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
Vue报错:Injection "xxxx" not found的解决办法
这篇文章主要给大家介绍了关于Vue报错:Injection "xxxx" not found的解决办法,文中通过图文将解决的办法介绍的非常详细,对大家的学习具有一定的参考借鉴价值,需要的朋友可以参考下2023-07-07Vue3 使用v-md-editor如何动态上传图片的方法实现
本文主要介绍了Vue3 使用v-md-editor如何动态上传图片,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2022-08-08解决Vue中使用Echarts出现There is a chart instance already ini
使用echarts的时候,多次加载会出现There is a chart instance already initialized on the dom.这个黄色警告,此警告信息不影响echarts正常加载,但是有bug得解决,本文就带大家解决这个问题,感兴趣的同学可以参考阅读2023-06-06
最新评论