vue element popover input focus() 不生效 解决办法

博客内容讲述了在使用element-ui的popover组件时遇到的问题,即popover内的input元素在触发显示时无法自动获取焦点,导致用户必须手动点击才能开始输入。为了解决这个问题,作者通过在popover的show事件中利用$nextTick延迟执行,成功地使input在popover显示后自动获取焦点。这种方法提高了用户体验,避免了额外的手动操作。

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

popover中有input
但是在点击触发popover时,input未获取到焦点
需要手动点击才能输入,效果如图
在这里插入图片描述
影响用户体验, 需要改进一下

首先想到的方法是 给el-input 添加ref,获取后调用focus()

<el-input
      placeholder="请输入内容"
      v-model="value"
      clearable
      @keyup.enter.native="confirm"
      ref="sInput"
    >
this.$refs.sInput.focus()

但是不生效。
查阅资料后发现 需要在popover的show event中手动给el-input获取焦点

<el-popover placement="bottom" width="200" trigger="manual" v-model="visible" @show="showPopover">
    <el-input
      placeholder="请输入内容"
      v-model="value"
      clearable
      @keyup.enter.native="confirm"
      ref="sInput"
    >
</el-popover>
methods: {
      showPopover () {
        this.$nextTick(() => {
        this.$refs.sInput.focus()
        })
      },

这样就完成了,功能实现

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值