vue3中el-input无法获得焦点的问题

文章目录

现象

el-input被外层div包裹了,设置autofocus不起作用:

html 复制代码
<el-dialog v-model="visible" :title="title" :append-to-body=true width="50%">
    <el-form v-model="theForm" @submit.prevent="submit">
      <el-form-item v-for="item in formItems" :label="item.label" :label-width="120">
        <el-input v-model="theForm[item.name]" ref="inputRef"
          autocomplete="off"           
          @keyup.enter.stop="submit"
          autofocus/>
      </el-form-item>
    </el-form>
    <template #footer>
        <span>
          <el-button type="primary" @click="cancel()">取消</el-button>
          <el-button type="primary" @click="submit()">确定</el-button>
        </span>
    </template>
  </el-dialog>

在onMounted()中尝试: inputRef.value.focus(),也无效。怀疑是调用时机不对,但何时才是页面dom都生成好的时机呢?

两次nextTick()加setTimeout()解决

javascript 复制代码
// 需要调用两次nextTick才能获得实例!!!
const focusInput = () => { nextTick(() => 
  nextTick(()=>{    
    setTimeout(function () {
      let _eles = document.querySelectorAll('form input.el-input__inner')
      // console.log(_eles)
      _eles[0].focus()
      // inputRef.value.focus()
    }, 100);
    
  }))}

onMounted(() => {
  focusInput()
})

结论

在vue3组件嵌套复杂时,很难确定组件之间的初始化顺序,这时尽可能让访问时机靠后是一个通用的解决方法。

相关推荐
阿芯爱编程1 分钟前
前端最新面试题
前端·面试
谁点的猪脚饭2 分钟前
vue2 element-ui 中 el-radio 单选框点击事件失效问题
vue.js·elementui·vue2
天天扭码6 分钟前
一分钟吃透一道面试算法题——字母异位词分组(最优解)
前端·javascript·算法
天天扭码18 分钟前
JavaScript 中字符串转字符数组的两种优雅方式
前端·javascript·代码规范
何遇er20 分钟前
在 AI 编程的热潮下对低代码的思考
前端·低代码·ai编程
何遇er23 分钟前
一句 Prompt 自动生成表单:我在低代码平台里是怎么接入生成式 AI 的
前端·低代码·ai编程
_一条咸鱼_25 分钟前
Vue 指令模块深度剖析:从基础应用到源码级解析(十二)
前端·javascript·面试
薯条不要番茄酱33 分钟前
【JavaEE初阶】多线程重点知识以及常考的面试题-多线程进阶(一)
java·前端·java-ee
苹果酱056743 分钟前
redis系列--1.redis是什么
java·vue.js·spring boot·mysql·课程设计
只会安静敲代码的 小周1 小时前
uniapp上传图片时(可选微信头像、相册、拍照)
前端·微信·uni-app