40
38

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

Vue.js で表示に切り替えたDOMにフォーカスできないときは $nextTick を使う

Last updated at Posted at 2017-06-24

次のように、ボタン「A」を押すと右に入力フィールドが現われるようなものを作ったとき、たいてい、そのフィールドにフォーカスさせたくなってきます。これが難しい。

スクリーンショット 2017-06-24 23.11.56.png

すぐに focus() しても、まだその DOM は表示されていないので、フォーカスが空振りしてしまいます。

そのようなときは、次のように $nextTick を使ってタイミングをずらすとよさそうです。

<div id="app">
  <button @click="c">A</button>
  <input v-if="s" ref="r" />
</div>

<script src="https://unpkg.com/vue"></script>
<script>
  new Vue({
    el: "#app",
    data: {s: false},
    methods: {
      c() {
        this.s = true
        this.$nextTick(() => this.$refs.r.focus())
      },
    },
  })
</script>

これでうまくいきました。

参照

vm.$nextTick https://jp.vuejs.org/v2/api/#vm-nextTick

40
38
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
40
38

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?