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

相关推荐
年纪轻轻只想躺平12 分钟前
JavaScript ES6+ 最佳实践
前端·javascript·es6
Edward-tan13 分钟前
【玩转全栈】—— 无敌前端究极动态组件库--Inspira UI
前端·spira-ui
qq_2780637133 分钟前
vue2 结合后端预览pdf 跨域的话就得需要后端来返回 然后前端呈现
前端·pdf
桥豆麻袋939335 分钟前
vite 初始化react项目
前端·react.js·前端框架
CHQIUU36 分钟前
使用 CDN 在国内加载本地 PDF 文件并处理批注:PDF.js 5.x 实战指南
开发语言·javascript·pdf
2401_8370885036 分钟前
CSS相对定位与绝对定位
前端·css
梦想平凡1 小时前
开元类双端互动组件部署实战全流程教程(第1部分:环境与搭建)
运维·服务器·前端·游戏·node.js
HelloRevit1 小时前
React -> AI组件 -> 调用Ollama模型, qwen3:1.7B非常聪明
前端·react.js·前端框架
geovindu2 小时前
javascript: Multi-page PDF in Canvas using PDFJS 5.1
前端·javascript
暮 夏2 小时前
利用session在html和MySQL实现登录
前端·mysql·html