JavaScript

チェックボックスの選択状態を取得・変更する

  1. 最終更新日:
  2. 公開日:

フォームのチェックボックスの選択状態を取得したり、変更する方法について解説します。

この記事のポイント

  • チェックボックスの選択状態はcheckedプロパティを参照する
  • checkedプロパティtrueを入れると選択状態、falseを入れると選択解除

チェックボックスの選択状態を取得する

フォームの入力項目の1つであるチェックボックスについて、選択状態を取得するときはcheckedプロパティを参照します。
checkedプロパティは選択された状態のときはtrue、選択されていないときはfalseが入ります。

今回は解説用に以下のHTMLコードを使います。
赤字のHTML要素がチェックボックスのHTMLです。

HTMLコード例

<form method="post" action="">
  <label for="agree"><input type="checkbox" id="agree" name="agree" value="1">同意する</label>
</form>

以下の例では上記のチェックボックスにイベントリスナー「change」を登録して、選択したり選択解除があったときに選択状態を取得するように設定します。

JavaScript コード例

window.addEventListener('DOMContentLoaded', function(){

  // チェックボックスのHTML要素を取得
  let input_agree = document.querySelector("input[name=agree]");

  input_agree.addEventListener('change',function(){
    console.log(this.checked); // 選択されたらtrue、選択解除はfalse
  });
});

1行目はページ読み込み時に実行するイベントリスナーを登録しています。
その中で、まずはquerySelectorメソッドを使ってチェックボックスのHTML要素をname属性から取得します。

続いて、チェックボックスのHTML要素に対してイベントリスナーで「change」を登録します。
これで、チェックボックスが選択されたり選択解除される度にここの中の処理が呼び出されるようなります。

最後に、checkedプロパティを参照して値を出力します。
this」はイベントリスナーに登録したHTML要素自身(ここではチェックボックス)を指します。

チェックボックスの選択状態を変更する

選択状態を変更するときについても、checkedプロパティから行います。
選択状態にするときはcheckedプロパティtrueを入れ、選択解除するときはfalseを入れます。

以下の例はページが読み込まれたタイミングでチェックボックスを選択状態に設定します。

JavaScript コード例

window.addEventListener('DOMContentLoaded', function(){

  // チェックボックスのHTML要素を取得
  let input_agree = document.querySelector("input[name=agree]");

  if( !input_agree.checked ) {
    input_agree.checked = true;
  }
});

if文の条件式でチェックボックスの選択状態を確認します。
falseになっているときのみ、if文の中でtrueを設定して選択状態に変更します。

記事一覧

関連記事