码迷,mamicode.com
首页 > 其他好文 > 详细

Vue 中如何让 input 聚焦?

时间:2020-10-18 16:23:48      阅读:28      评论:0      收藏:0      [点我收藏+]

标签:https   targe   str   tar   NPU   生命周期   attr   自定义   状态   

在做项目时,有时我们需要让 input 聚焦,为了让用户更好的使用。

 

让 input 聚焦

所有的浏览器都有一个内置的方法,让 input 聚焦。首先,我们需要获取元素。

在原生 js 中,我们可以使用下面方式来获取元素:

<form>
  <input id="email" />
</form>

const input = document.getElementById(‘email‘);

vue 提供了一个更好的方法:

<template>
  <input ref="email" />
</template>

const input = this.$refs.email;    

获取元素后,我们就可以让 input 聚焦了

<template>
  <input ref="email" />
</template>

export default {
  methods: {
    focusInput() {
      this.$refs.email.focus();
    }
  }
}

如果使用的是自定义组件,则$ref获取是该组件,而不是我们基础元素。 因此,如果尝试让该组件聚焦,就会报错。要获得自定义组件的根元素,我们可以用 $el 访问:

<template>
  <CustomInput ref="email" />
</template>
    
import CustomInput from ‘./CustomInput.vue‘;

export default {
  components: {
    CustomInput,
  },
  methods: {
    focusInput() {
      this.$refs.email.$el.focus();
    }
  }
}

但是,如果要在组件加载时就聚焦,要怎么做呢?

 

页面加载时聚焦

我们可以 mouted 生命周期,让元素聚焦:

<template>
<CustomInput ref="email" />
</template>
import CustomInput from ‘./CustomInput.vue‘;

export default {
  components: {
    CustomInput,
  },
  mounted() {
    this.focusInput();
  },
  methods: {
    focusInput() {
      this.$refs.email.$el.focus();
    }
  }
}

电脑刺绣绣花厂 http://www.szhdn.com 广州品牌设计公司https://www.houdianzi.com

等待重新渲染

在某些情况下,我们可能需要等待Vue完成整个应用程序的重新渲染。例如,如果将input从隐藏状态切换到显示状态。

因此我们需要等待 input 加载好后,才能重新聚焦。

<template>
  <div>
    <CustomInput v-if="inputIsVisible" ref="email" />
  </div>
</template>

import CustomInput from ‘./CustomInput.vue‘;

export default {
  components: {
    CustomInput,
  },
  data() {
    return {
      inputIsVisible: false,
    };
  },
  mounted() {
    this.focusInput();
  },
  methods: {
    showInput() {
      // Show the input component
      this.inputIsVisible = true;

      // Focus the component, but we have to wait
      // so that it will be showing first.
      this.nextTick(() => {
        this.focusInput();
      });
    },
    focusInput() {
      this.$refs.email.$el.focus();
    }
  }
}

这里,我们在 nextTick 方法中调用 focusInput 方法。因为 nextTick 中表示 Dom 已经加载完成了,所以这时我们才能获取到 input 元素。

Vue 中如何让 input 聚焦?

标签:https   targe   str   tar   NPU   生命周期   attr   自定义   状态   

原文地址:https://www.cnblogs.com/Qooo/p/13826425.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!