0
0

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.

エンターキーでsubmitしたくないフォームをJavaScriptで制御する

Last updated at Posted at 2020-01-10

入力フォームを選択した状態でエンターキーではsubmitしたくない(送信ボタンを押下した時だけsubmitしたい)場合、以下JSで制御できる。


// 当該formのdata属性にdisallow-enter-submitを指定している前提
const forms = Array.from(document.querySelectorAll('form')).filter(el => el.getAttribute('data-disallow-enter-submit'));
if (!forms.length) return;

for (let i = 0; i < forms.length; i += 1) {
  const form = forms[i];
  form.addEventListener('keydown', e => {
    if (
      ((e.which && e.which === 13) || (e.keyCode && e.keyCode === 13)) && e.target.tagName !== 'TEXTAREA'
    ) {
      e.preventDefault();
      return false;
    }
    return true;
  });
}

補足


((e.which && e.which === 13) || (e.keyCode && e.keyCode === 13)) && e.target.tagName !== 'TEXTAREA'
  • 13はエンターキーのこと。
  • whichkeyCodeの両方を指定しているのは、ブラウザによって挙動が異なるため。
  • テキストエリア(複数行)を選択した状態だと、改行のためにエンターを押しただけでイベントがトリガーされて改行ができなくなってしまうため、TEXTAREAでない場合という条件も追加している。
0
0
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
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?