ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
output 要素とは
<output> は HTML5 で導入された計算結果やスクリプトの出力を表現する要素です。<span> でも結果を表示できますが、<output> は意味的に「これは計算結果である」と明示できる点で SEO とアクセシビリティの両方で有利です。
基本構文
<form oninput="result.value = parseInt(a.value) + parseInt(b.value)">
<input type="number" id="a" name="a" value="10"> +
<input type="number" id="b" name="b" value="20"> =
<output name="result" for="a b">30</output>
</form>
属性一覧
| 属性 | 意味 | 例 |
|---|---|---|
for | 計算元の input の id(空白区切り) | for="a b" |
form | 所属する form の id | form="myform" |
name | フォーム送信時の name | name="result" |
range スライダーと組み合わせる
<input type="range"> は単体では現在値が見えないため、<output> で表示するのが王道パターンです。
<form oninput="vol.value = volume.value">
<label for="volume">音量:</label>
<input type="range" id="volume" name="volume" min="0" max="100" value="50">
<output name="vol" for="volume">50</output>
</form>
消費税計算の例
<form oninput="tax.value = Math.floor(price.value * 0.1);
total.value = parseInt(price.value) + parseInt(tax.value)">
<label>本体価格: <input type="number" id="price" value="1000"></label><br>
消費税: <output name="tax" for="price">100</output> 円<br>
合計: <output name="total" for="price">1100</output> 円
</form>
JavaScript からの値の設定
<output> の値は value プロパティでも textContent でも書き換えられますが、値としての意味を持たせるなら value を使うのが推奨です。
const out = document.querySelector('output[name="result"]');
out.value = 42; // HTMLOutputElement#value
// または
out.textContent = '42'; // どの要素でも使える方法
<output> vs <span>
| 項目 | <output> | <span> |
|---|---|---|
| 意味 | 計算結果である | 意味なし(インライン汎用) |
| aria role | status(暗黙) | なし |
| form 連携 | あり(name で送信値に含む) | なし |
| JS から value で操作 | 可 | 不可(textContent のみ) |
アクセシビリティ
<output> はデフォルトで aria-live="polite" 相当の挙動を持ちます。値が変化するとスクリーンリーダーが適切なタイミングで読み上げます。計算結果や進捗表示には <span> ではなく <output> を使うことで、視覚障害者にも結果が伝わります。
ブラウザサポート
HTML5 標準で、主要ブラウザ(Chrome / Firefox / Safari / Edge)でいずれも対応済み。IE は非対応ですが、現在はサポート対象外のため気にする必要はありません。
FAQ
Q: oninput と onchange のどちらを使うべき?
A: 入力中のリアルタイム反映には oninput。フォーカスが離れたタイミングで反映したいなら onchange。<output> との組み合わせは oninput が一般的です。
Q: <output> は送信されるか?
A: name 属性を持つ <output> は FormData に含まれます。ただし通常のフォーム送信(application/x-www-form-urlencoded)では送信されないブラウザもあるため、JS で FormData 経由で扱うのが確実です。
関連
- form 要素 — フォームの親要素
- input 要素 — type=range や type=number と組み合わせる
- progress 要素 — 進捗表示。output より進捗向け
- meter 要素 — 範囲のある値(ディスク使用量等)の表示
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
人気ページ
- 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・デュアルスタック 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 2026-06-22 12:19:10
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 2026-06-22 12:17:25
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?