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

相关推荐
hxmmm15 小时前
js中生成器和迭代器
前端
阿登林15 小时前
Vue面试项目经验分享:如何专业展示技术能力与解决问题
vue.js·经验分享·面试
黄交大彭于晏15 小时前
UniApp 全局通知功能实现
前端·vue.js·uni-app
sTone8737516 小时前
Android核心概念(一)minSdkVersion targetSdkVersion compileSdkVersion
android·前端
林太白16 小时前
八大数据结构
前端·后端·算法
一 乐16 小时前
流浪动物救助|流浪猫狗救助|基于Springboot+vue的流浪猫狗救助平台设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·spring boot·毕设
火星数据-Tina16 小时前
Python + WebSocket 实现实时体育比分系统(含数据库设计与前端演示)
开发语言·前端
国思RDIF框架16 小时前
国思RDIF低代码快速开发框架 v6.2.2版本发布
前端·vue.js·后端
oil欧哟16 小时前
Agent 设计与上下文工程- 02 Workflow 设计模式(上)
前端·网络·人工智能
StarkCoder16 小时前
GetX 状态管理优化:从 GetBuilder 到 Obx 的性能提升实践
前端