8
10

More than 5 years have passed since last update.

formのsubmit関数を使うときは、formタグの中にidまたはnameがsubmitとなっている入力項目を含めてはいけない

Last updated at Posted at 2014-02-25

id または name 属性が submit となっている入力項目(input, select タグなど)が form タグ内に存在する場合、その form の submit() 関数を実行すると、

Uncaught TypeError: Property 'submit' of object #<HTMLFormElement> is not a function

というエラーが発生する。

<form id="form-1">
</form>

<form id="form-2">
    <input type="button" id="submit" />
</form>

<form id="form-3">
    <input type="button" name="submit" />
</form>

<form id="form-4">
    <div id="submit"></div>
</form>

<form id="form-5">
    <select id="submit"></select>
</form>
console.log(document.getElementById('form-1').submit);
// > function submit() { [native code] }
console.log(document.getElementById('form-2').submit);
// > <input type="button" id="submit" />
console.log(document.getElementById('form-3').submit);
// > <input type="button" name="submit" />
console.log(document.getElementById('form-4').submit);
// > function submit() { [native code] } 
console.log(document.getElementById('form-5').submit);
// > <select id="submit"></select>

id または namesubmit となっている入力項目タグが存在する場合、 form の submit プロパティは関数ではなく、当該タグの DOM オブジェクトを指してしまっている。

今回このエラーに遭遇したときは、 jQuery の submit() 関数を使用していたが、これも結局は内部で form タグの submit プロパティを関数として実行しようとしているので、同じようにエラーになってしまう。

参考

8
10
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
8
10