フォーム(Form)

目次

フォームを操作する

JavaScript とフォームをくみ合わせることによって、いろいろなことができます。下記の例では、2つの入力フォームに入力した値の合計を表示します。

HTML
<script>
function func() {
  var xx = parseFloat(document.F1.T1.value);
  var yy = parseFloat(document.F1.T2.value);
  document.F1.T3.value = xx + yy;
}
</script>
<form name="F1" action="#">
<input type="text" name="T1">
+
<input type="text" name="T2">
<input type="button" value="=" onclick="func()">
<input type="text" name="T3">
</form>

OK ボタンを押したとき(onclick)に、func() という名前の関数が呼び出されます。func() では、ドキュメント(document)の中の F1 という名前のフォーム(form)の中の、T1 という名前の部品の値(value)を数値に変換(parseFloat())し、変数 xx に代入しています。同様に yy に T2 欄の値を入れて、その合計を T3 の欄に表示しています。

フォームの値は文字列なので、これを数値として扱う場合は、parseFloat() などの数値変換を用いてください。例えば次の例で、入力欄に 100 を代入して OK を押すと、100 + 100 で 200 になりそうですが実際には "100" + 100 が文字列演算と見なされて、結果は "100100" になってしまいます。

HTML
<script>
function func() {
  alert(document.F1.T1.value + 100);
}
</script>
<form name="F1" action="#">
<input type="text" name="T1" value="100">
<input type="button" value="OK" onclick="func()">
</form>

フォームオブジェクト

window.document.forms

window.document.forms.length

forms は <form>~</form> に対応するフォームオブジェクトの配列を、length はその個数を示します。

window.document.form

個々のフォームオブジェクトを示します。0 から始まる通し番号の他、<form> タグの name 属性で指定したフォーム名(例では "FORM1")を用いて直接参照することもできます。

JavaScript
f = document.forms[0];
f = document.forms["FORM1"];
f = document.FORM1;

window.document.form.action

window.document.form.encoding

window.document.form.method

window.document.form.name

window.document.form.target

それぞれ、<form> タグで指定した action、encoding、method、name、target 属性の値を示します。

window.document.form.submit()

window.document.form.reset()

それぞれ、フォームのサブミットボタン、リセットボタンを押したのと同じ効果を起こします。

window.document.form.handleEvent(event)

フォームのイベントハンドラを呼び出します。

フォーム部品

window.document.form.elements

window.document.form.elements.length

elements はフォームを構成する各々の部品(エレメント)オブジェクトの配列、length はその個数を示します。

window.document.form.element

フォームを構成する個々のエレメントオブジェクトを指定します。0 から始まる通し番号や、<input> タグなどの name 属性で指定したエレメント名(例では "ELEM1")を用いて参照します。

JavaScript
e = document.FORM1.elements[0];
e = document.FORM1.ELEM1;

それぞれの部品は、共通プロパティや共通メソッドの他、そのタイプによって異なるプロパティやメソッドをサポートします。

フォーム部品(共通)

window.document.form.element.name

name 属性で指定した、このフォーム部品の名前を示します。

window.document.form.element.type

"text" や "submit" などの、このフォーム部品のタイプを示します。

window.document.form.element.form

このフォーム部品を包含するフォームオブジェクトを示します。

window.document.form.element.value

このフォーム部品の値。text, password, textarea の場合は入力された文字列、button, submit, reset の場合はボタンに表示される文字列となります。textarea の場合、改行コードは通常、文字コード 0x0d 0x0a で表されますが、Netscape 6.1 は 0x0a のみになるようです。

window.document.form.element.focus()

window.document.form.element.blur()

focus() はこのエレメントにフォーカスを移し、blur() はこのエレメントからフォーカスをはずします。

フォーム部品(テキスト部品)

テキスト部品(<input type="text">)、パスワード部品(<input type="password">)、ファイル部品(<input type="file">)、テキストエリア部品(<textarea>)は、共通プロパティや共通メソッドの他に下記のプロパティやメソッドをサポートしています。

window.document.form.text.defaultValue

初期値として表示する文字列を示します。ただし、セキュリティのため、ファイル部品に対しては設定することができません。

window.document.form.text.select()

入力フィールド内の文字列を選択状態にします。下記のようにすることで、その入力フィールドにフォーカスが移った際に、入力済みの文字列をすべて選択状態にすることができます。

HTML
<input type="text" onfocus="this.select()">

フォーム部品(ボタン部品)

チェックボックス部品(<input type="checkbox">)、 ラジオボタン部品(<input type="radio">)、 ボタン部品(<input type="button">)、サブミット部品(<input type="submit">)、 リセット部品(<input type="reset">)は、共通プロパティや共通メソッドの他に下記のプロパティやメソッドをサポートしています。

window.document.form.checkbox.defaultChecked

window.document.form.checkbox.checked

チェックボックスとラジオボタンにのみ有効です。defaultChecked は初期値としてチェックされていたかどうか、checked は現在チェックされているかどうかを示す真偽値を返します。checked に true や false を代入することもできます。

チェックボックスがチェックされているかどうかを調べるには次のようにします。

HTML
<script>
function func() {
  if (document.F1.C1.checked) {
    alert(document.F1.C1.value);
  }
  if (document.F1.C2.checked) {
    alert(document.F1.C2.value);
  }
}
</script>
<form name="F1" action="#">
<input type="checkbox" name="C1" value="AAA">AAA
<input type="checkbox" name="C2" value="BBB">BBB
<input type="button" value="OK" onclick="func()">
</form>

ラジオボタンがチェックされているかどうかを調べるには次のようにします。

HTML
<script>
function func() {
  var i;
  if (document.F1.R1.length) {
    for (var i = 0; i < document.F1.R1.length; i++) {
      if (document.F1.R1[i].checked) {
        alert(document.F1.R1[i].value);
      }
    }
  } else {
    if (document.F1.R1.checked) {
      alert(document.F1.R1.value);
    }
  }
}
</script>
<form name="F1" action="#">
<input type="radio" name="R1" value="AAA" checked>AAA
<input type="radio" name="R1" value="BBB">BBB
<input type="radio" name="R1" value="CCC">CCC
<input type="button" value="OK" onclick="func()">
</form>

window.document.form.checkbox.click()

このボタンををクリックした状態にします。

フォーム部品(セレクト部品)

セレクト部品(<select>)は、共通プロパティや共通メソッドの他に下記のプロパティをサポートしています。

window.document.form.select.length

オプション部品の個数、下記の options.length と同じ意味を持ちます。

window.document.form.select.selectedIndex

現在選択されているオプションオブジェクトを示すインデックス番号(0~)を示します。これに値を代入することにより、セレクションボックスの選択項目を変更することができます。

HTML
<script>
function func() {
  var n = document.F1.S1.selectedIndex;
  alert(document.F1.S1.options[n].text);
}
</script>
<form name="F1" action="#">
<select name="S1">
<option>AAAA
<option>BBBB
<option>CCCC
</select>
<input type="button" value="OK" onclick="func()">
</form>

フォーム部品(オプション部品)

オプション部品(<option>)は、共通プロパティや共通メソッドの他に下記のプロパティをサポートしています。

window.document.form.select.options

window.document.form.select.options[n]

window.document.form.select.options.length

options は<option>に対応するオプションオブジェクトの配列、options[n] は個々のオブジェクト、length は配列の個数を示します。

window.document.form.select.option.defaultSelected

window.document.form.select.option.selected

defaultSelected は初期値として選択されていたかどうかを示す真偽値、selected は現在選択されているかどうかを示す真偽値を返します。

window.document.form.select.option.text

オプションとして表示されている文字列を返します。

window.document.form.select.option.value

<option> タグの value 属性の値を返します。