el-input 自动获取焦点

前言:

需求描述:在 Dialog 对话框中 使用 input 组件;当点击按钮,Dialog 对话框显示,且里面的 input 组件要自动获取焦点。因为页面上还存在其他的 input 组件,所以使用 自动获取焦点属性没用!!

解决方案:

使用了 Dialog 组件关闭即销毁属性还是不行,最后通过在 Dialog 组件上使用 v-if 达到自己想要的效果

javascript 复制代码
<template>
  <div class="search_box" @click="openDialog">
    <el-icon><Search /></el-icon><span>搜索</span>
  </div>
  <el-dialog
    v-model="dialogTableVisible"
    top="6vh"
    :show-close="false"
    destroy-on-close
    v-if="dialogTableVisible"
  >
    <el-input
      v-model="input3"
      style="max-width: 600px"
      placeholder=""
      class="input-with-select"
      ref="input_dom"
      @keyup.enter="searchByWord"
    >
      <template #prepend>
        <el-select v-model="select" placeholder="搜索内容" style="width: 115px">
          <el-option label="卡片搜索" value="1" />
          <el-option label="内容搜索" value="2" />
        </el-select>
      </template>
    </el-input>
  </el-dialog>
</template>
<script>
import { Search } from "@element-plus/icons-vue";
export default {
  data() {
    return {
      dialogTableVisible: false,
      select: "1",
      input3: null,
    };
  },
  components: {
    Search,
  },
  methods: {
    searchByWord() {
      this.$emit("ChangeSearch", {
        value: this.select,
        querySearch: this.input3,
      });
      this.dialogTableVisible = false;
    },
    openDialog() {
      this.dialogTableVisible = true;
      this.$nextTick(() => {
        this.$refs.input_dom.focus();
      });
    },
  },
};
</script>
<style lang="scss" scoped>
.search_box {
  display: flex;
  align-items: center;
  cursor: pointer;
}
</style>

核心代码:

相关推荐
码农胖大海21 小时前
微前端架构(二):封装与实现
前端
瘦的可以下饭了21 小时前
2 数组 递归 复杂度 字符串
前端·javascript
Kellen21 小时前
ReactDOM.preload
前端·react.js
岭子笑笑21 小时前
vant 4 之loading组件源码阅读
前端
hxmmm21 小时前
自定义封装 vue多页项目新增项目脚手架
前端·javascript·node.js
ETA821 小时前
JS执行机制揭秘:你以为的“顺序执行”,其实是V8引擎在背后搞事情!
前端·javascript
鹏北海-RemHusband21 小时前
微前端实现方式:HTML Entry 与 JS Entry 的区别
前端·javascript·html
瘦的可以下饭了1 天前
3 链表 二叉树
前端·javascript
我那工具都齐_明早我过来上班1 天前
WebODM生成3DTiles模型在Cesium地图上会垂直显示问题解决(y-up-to-z-up)
前端·gis
粉末的沉淀1 天前
jeecgboot:electron桌面应用打包
前端·javascript·electron