32
9

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 3 years have passed since last update.

TypeScriptでInputEventを扱うときの正しいアプローチ

Posted at

TypeScriptでinputイベントのevent.target.valueを参照しようとすると、型エラーとなります。

const inputField = document.getElementById('inputField');

inputField.addEventListener('input', (event) => {
  const value = event.target.value; // Property 'value' does not exist on type 'EventTarget'.
});

これは、event.targetの型が確定していないため発生します。

正しくはevent.targetの型チェックを行って想定される要素ではないことを確認します。

// Input要素の場合
const inputField = document.getElementById('inputField');

inputField.addEventListener('input', (event) => {
  const { target } = event;

  // Input要素以外の場合は終了
  if (!(target instanceof HTMLInputElement)) {
    return;
  }

  const value = target.value; // 👍
});
// TextArea要素の場合
const textareaField = document.getElementById('textareaField');

inputField.addEventListener('input', (event) => {
  const { target } = event;

  // TextArea要素以外の場合は終了
  if (!(target instanceof HTMLTextAreaElement)) {
    return;
  }

  const value = target.value; // 👍
});

一手間かかりますが、これでより型安全にInputEventを扱えるようになります。

32
9
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
32
9

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?