vue之输入框聚焦

文章介绍了在Vue框架下如何实现表单输入框的自动聚焦。通过使用$nextTick方法确保在DOM更新后调用this.$refs.ipt.focus()实现聚焦。在v-for循环中,可以给每个输入框设置相同的ref,然后通过数组索引访问并聚焦特定输入框。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

当打开一个表单,要聚焦输入框,用vue如何实现

知识点

  • 首先想到聚焦的事件focus();
  • 调用事件得先获取元素,this.$refs.iptTerminal[param]
  • 组件打开时获取元素,在$nextTick中,防止获取不到;

基本用法

<template>
<el-input ref="ipt"></el-input>
</template>
<script>
this.$nextTick(()=>{
	this.$refs.ipt.focus();
});
</script>

v-for时聚焦

背景:当输入框是v-for渲染时,如何获取DOM元素并聚焦

思路:

  1. 给每个输入框(el-input)相同的ref值
  2. 获取vue元素时通过数组获取
<template>
<el-input v-for="(item,index) in arr" ref="ipt"></el-input>
</template>
<script>
this.$nextTick(()=>{
	// 假设,我想聚焦第三个输入框
	this.$refs.ipt[3].focus();
});
</script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值