ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
フォーム部品の変更を検知する 3 つの方法
HTML のフォーム部品(テキストボックス・セレクトボックス・ラジオボタン)で値の変化を検知したいときに使うイベントは、用途によって change / input / keyup を使い分けます。属性として書く場合と addEventListener で登録する場合の両方を押さえておきましょう。
onchange — 値が確定した時点で呼ぶ
テキストボックスではフォーカスが外れた瞬間、セレクトボックス・ラジオボタンでは選択が変わった瞬間に発火します。
<input type="text" onchange="testFunc()" />
<select onchange="testFunc()">
<option value="A">A</option>
<option value="B">B</option>
</select>
<input type="radio" name="r" value="1" onchange="testFunc()" />
テキストボックスで onchange を使うと、入力中はずっと無反応で、外をクリックして初めて関数が呼ばれます。「確定した値だけ処理したい」用途に向いています。
oninput — 1 文字ごとに呼ぶ
テキストボックス・テキストエリアの入力内容が変化した瞬間に発火します。コピー&ペーストや IME 確定でも反応するため、リアルタイム処理に最適です。
<input type="text" oninput="testFunc(this.value)" />
<textarea oninput="countChars(this)"></textarea>
リアルタイム検索のサジェスト・文字数カウンタ・入力バリデーションは oninput 一択です。
onkeyup — キーを離した時点で呼ぶ
キーボードのキーが離された瞬間に発火します。oninput との違いは、IME 変換中やコピー&ペースト時の挙動です。
<input type="text" onkeyup="testFunc()" />
| イベント | 発火タイミング | IME 変換中 | ペースト |
|---|---|---|---|
change | フォーカスを失った時 | 影響なし | 反応する |
input | 値が変わるたび | 確定時のみ | 反応する |
keyup | キーを離した瞬間 | 1 キーごとに発火 | 反応しない |
addEventListener による登録
属性に書く方法(HTML 属性ハンドラ)は手軽ですが、CSP(Content Security Policy)でインライン JS を禁止している環境では使えません。実務では addEventListener で登録するのが推奨です。
const input = document.querySelector('#myInput');
input.addEventListener('change', () => {
console.log('値が確定:', input.value);
});
input.addEventListener('input', (e) => {
console.log('入力中:', e.target.value);
});
addEventListener なら複数のハンドラを 1 要素に登録できるほか、{ once: true } や { passive: true } といったオプションも指定できます。
ラジオボタンで onchange を使う例
同じ name を持つラジオボタンは、選択が切り替わるたびに新しく選ばれた input で change が発火します。
<label><input type="radio" name="size" value="S" onchange="selectSize(this.value)" /> S</label>
<label><input type="radio" name="size" value="M" onchange="selectSize(this.value)" /> M</label>
<label><input type="radio" name="size" value="L" onchange="selectSize(this.value)" /> L</label>
<script>
function selectSize(v) {
console.log('選ばれたサイズ:', v);
}
</script>
よくある落とし穴
Q: テキストボックスで onchange が動かない
A: change はフォーカスを失った時にしか発火しません。入力中に処理したいなら oninput を使ってください。
Q: 日本語入力で文字数カウントがズレる
A: oninput は IME 変換確定時に発火するため、確定前の予測変換段階は数えられません。確定後の値のみで計算する設計にしましょう。
Q: スマートフォンで onkeyup が反応しない
A: ソフトウェアキーボードは物理キー入力ではないため、keyup イベントが発火しない端末があります。モバイル対応では input を使ってください。
関連
- HTML — 親カテゴリ
- JavaScript — 言語側のリファレンス
- input要素 — テキスト・ラジオの基本
- select 要素 / textarea 要素 — その他のフォーム部品
- addEventListener / removeEventListener — 推奨のイベント登録 API
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- 環境構築
- 文法
- 要素一覧
- API
- テンプレートエンジン
- <head>タグに書いた内容が<body>タグに移動する場合の解決方法
- 空白(スペース)の入力方法
- テキスト/セレクトボックス/ラジオボタン変更時のJS関数呼び出し
- buttonでformをsubmitさせない方法
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック NEW 2026-06-22 12:34:44
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 NEW 2026-06-22 12:19:10
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 NEW 2026-06-22 12:19:10
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 NEW 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 NEW 2026-06-22 12:17:25
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 NEW 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 NEW 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 NEW 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 NEW 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 NEW 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 NEW 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 NEW 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 NEW 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?