--- title: HTML 属性リファレンス slug: Web/HTML/Attributes tags: - 属性 - 初心者 - 要素の属性 - 要素 - HTML - リファレンス - 設定 - ウェブ translation_of: Web/HTML/Attributes --- {{HTMLSidebar}} HTML の要素は**属性**を持ちます。ユーザーが望む条件を満たすために、さまざまな方法で要素を構成したり、動作を調整したりする追加の値です。 ## グローバルイベントハンドラー 下記の表に並んでいる属性に加えて、 [`GlobalEventHandlers`](/ja/docs/Web/API/GlobalEventHandlers) の記事ではグローバルイベントハンドラー — [`onclick`](/ja/docs/Web/API/GlobalEventHandlers/onclick) など — を並べています。これもすべての要素で[コンテンツ属性](#コンテンツ属性と_idl_属性)として指定することができます。 ## 属性一覧
属性名 要素 説明
accept {{ HTMLElement("form") }}, {{ HTMLElement("input") }} サーバーの受容する型のリストです。ふつうはファイル形式です。
accept-charset {{ HTMLElement("form") }} 対応している文字集合のリストです。
accesskey グローバル属性 要素をアクティブ化したり、フォーカスを与えたりするためのショートカットキーです。
action {{ HTMLElement("form") }} フォーム経由で送信される情報を処理するプログラムの URI です。
align {{ HTMLElement("applet") }}, {{ HTMLElement("caption") }}, {{ HTMLElement("col") }}, {{ HTMLElement("colgroup") }}, {{ HTMLElement("hr") }}, {{ HTMLElement("iframe") }}, {{ HTMLElement("img") }}, {{ HTMLElement("table") }}, {{ HTMLElement("tbody") }}, {{ HTMLElement("td") }}, {{ HTMLElement("tfoot") }} , {{ HTMLElement("th") }}, {{ HTMLElement("thead") }}, {{ HTMLElement("tr") }} 要素の水平方向の配置を指定します。
allow {{ HTMLElement("iframe") }} iframe の機能ポリシーを指定します。
alt {{ HTMLElement("applet") }}, {{ HTMLElement("area") }}, {{ HTMLElement("img") }}, {{ HTMLElement("input") }} 画像が表示できない場合の代替テキストです。
async {{ HTMLElement("script") }} スクリプトを非同期で実行します。
autocapitalize グローバル属性 ユーザーによる入力が入力欄で自動的に大文字化されるかどうかを設定します。
autocomplete {{ HTMLElement("form") }}, {{ HTMLElement("input") }}, {{ HTMLElement("select") }}, {{ HTMLElement("textarea") }} このフォーム内のコントロールが、ブラウザーによる値の自動補完を既定で許容するかを示します。
autofocus {{ HTMLElement("button") }}, {{ HTMLElement("input") }}, {{ HTMLElement("keygen") }}, {{ HTMLElement("select") }}, {{ HTMLElement("textarea") }} ページ読込後に、対象要素に自動的にフォーカスを当てるようにします。
autoplay {{ HTMLElement("audio") }}, {{ HTMLElement("video") }} オーディオやビデオが再生可能になった時点で自動再生を開始します。
background {{ HTMLElement("body") }}, {{ HTMLElement("table") }}, {{ HTMLElement("td") }}, {{ HTMLElement("th") }} 画像ファイルの URL を指定します。

注: ブラウザーや電子メールクライアントはまだこの属性に対応していますが、廃止済みです。代わりに CSS の {{ Cssxref("background-image") }} を使用してください。

bgcolor {{ HTMLElement("body") }}, {{ HTMLElement("col") }}, {{ HTMLElement("colgroup") }}, {{ HTMLElement("marquee") }}, {{ HTMLElement("table") }}, {{ HTMLElement("tbody") }}, {{ HTMLElement("tfoot") }}, {{ HTMLElement("td") }}, {{ HTMLElement("th") }}, {{ HTMLElement("tr") }}

要素の背景色です。

注: これは古い属性です。代わりに CSS の {{ Cssxref("background-color") }} プロパティを使用してください。

border {{ HTMLElement("img") }}, {{ HTMLElement("object") }}, {{ HTMLElement("table") }}

境界線の幅です。

注: これは古い属性です。代わりに CSS の {{ Cssxref("border") }} プロパティを使用してください。

buffered {{ HTMLElement("audio") }}, {{ HTMLElement("video") }} すでにバッファリングされたメディアの時間の範囲を示します。
capture {{ HTMLElement("input") }} Media Capture 仕様書から、キャプチャできる新しいファイルを指定します。
challenge {{ HTMLElement("keygen") }} 公開鍵とともに送信するチャレンジ文字列
charset {{ HTMLElement("meta") }}, {{ HTMLElement("script") }} ページまたはスクリプトの文字エンコーディングを宣言します。
checked {{ HTMLElement("command") }}, {{ HTMLElement("input") }} ページ読み込み時に要素にチェックを入れておくかどうかを指定します。
cite {{ HTMLElement("blockquote") }}, {{ HTMLElement("del") }}, {{ HTMLElement("ins") }}, {{ HTMLElement("q") }} 引用元または変更点の情報源を指す URI を格納します。
class グローバル属性 よく使われるプロパティで要素にスタイルを適用するために CSS と共によく用いられます。
code {{ HTMLElement("applet") }} 読み込んで実行するアプレットのクラスファイルの URL を指定します。
codebase {{ HTMLElement("applet") }} code 属性で参照するアプレットの .class ファイルを配置しているディレクトリの絶対 URL または相対 URL を指定します。
color {{ HTMLElement("basefont") }}, {{ HTMLElement("font") }}, {{ HTMLElement("hr") }}

この属性は色名または16進数の #RRGGBB 形式を用いて文字色を設定します。

注: これは古い属性です。代わりに CSS の {{Cssxref("color")}} プロパティを使用して下さい。

cols {{ HTMLElement("textarea") }} テキストエリアの桁数 (水平方向の文字数) を定義します。
colspan {{ HTMLElement("td") }}, {{ HTMLElement("th") }} colspan 属性はテーブルのセルを結合する列数を定義します。
content {{ HTMLElement("meta") }} 状況に応じて、 http-equiv または name に関連した値です。
contenteditable グローバル属性 要素の内容が編集可能であるかどうかを示します。
contextmenu グローバル属性 要素のコンテキストメニューとして機能する {{HTMLElement("menu")}} 要素の ID を定義します。
controls {{ HTMLElement("audio") }}, {{ HTMLElement("video") }} 再生コントロールをユーザーに表示すべきかどうかを示します。
coords {{ HTMLElement("area") }} ホットスポット領域の座標を指定するための値のセットです。
crossorigin {{ HTMLElement("audio") }}, {{ HTMLElement("img") }}, {{ HTMLElement("link") }}, {{ HTMLElement("script") }}, {{ HTMLElement("video") }} 要素がオリジン間リクエストをどう扱うか
csp {{experimental_inline}} {{ HTMLElement("iframe") }} 埋め込まれた文書が管理されるためのコンテンツセキュリティポリシーを指定します。
data {{ HTMLElement("object") }} リソースの URL を指定します。
data-* グローバル属性 HTML 要素にカスタム属性が添付できるようにします。
datetime {{ HTMLElement("del") }}, {{ HTMLElement("ins") }}, {{ HTMLElement("time") }} 要素に関連付けられた日時を示します。
decoding {{ HTMLElement("img") }} 画像をデコードする推奨の方法を示します。
default {{ HTMLElement("track") }} ユーザー設定によって異なることが示されていない限り、トラックが有効であることを示します。
defer {{ HTMLElement("script") }} ページの解釈が完了した後に実行するスクリプトであることを示します。
dir グローバル属性 テキストの書字方向を定義します。使用できる値は ltr (Left-To-Right) または rtl (Right-To-Left) です。
dirname {{ HTMLElement("input") }}, {{ HTMLElement("textarea") }}
disabled {{ HTMLElement("button") }}, {{ HTMLElement("command") }}, {{ HTMLElement("fieldset") }}, {{ HTMLElement("input") }}, {{ HTMLElement("keygen") }}, {{ HTMLElement("optgroup") }}, {{ HTMLElement("option") }}, {{ HTMLElement("select") }}, {{ HTMLElement("textarea") }} 閲覧者によるによるコントロールの操作を無効にするかどうかを示します。
download {{ HTMLElement("a") }}, {{ HTMLElement("area") }} リソースをダウンロードするためのハイパーリンクであるかどうかを示します。
draggable グローバル属性 要素がドラッグ可能であるかどうかを示します。
enctype {{ HTMLElement("form") }} method 属性が POST である場合に、フォームデータのコンテンツ型を定義します。
enterkeyhint {{experimental_inline}} {{ HTMLElement("textarea") }}, contenteditable enterkeyhint は、仮想キーボードの Enter キーにあるアクションラベル (またはアイコン) が何であるかを指定します。この属性はフォームコントロール (textarea 要素の値など) と共に、または編集対象となっている要素 (例えば contenteditable 属性の使用など) の中で使用することができます。
for {{ HTMLElement("label") }}, {{ HTMLElement("output") }} この要素が属する要素を指定します。
form {{ HTMLElement("button") }}, {{ HTMLElement("fieldset") }}, {{ HTMLElement("input") }}, {{ HTMLElement("keygen") }}, {{ HTMLElement("label") }}, {{ HTMLElement("meter") }}, {{ HTMLElement("object") }}, {{ HTMLElement("output") }}, {{ HTMLElement("progress") }}, {{ HTMLElement("select") }}, {{ HTMLElement("textarea") }} その要素が所属するフォームを示します。
formaction {{ HTMLElement("input") }}, {{ HTMLElement("button") }} その要素のアクションを示します。 {{ HTMLElement("form") }} で定義されたアクションを上書きします。
formenctype {{ HTMLElement("button") }}, {{ HTMLElement("input") }} button や input が送信ボタンである場合 (type="submit")、この属性はフォーム送信で使用するエンコーディング型を設定します。この属性が指定された場合、ボタンを所有するフォームenctype 属性より優先されます。
formmethod {{ HTMLElement("button") }}, {{ HTMLElement("input") }} button や input が送信ボタンである場合 (type="submit")、この属性はフォーム送信で使用する送信メソッド (GET, POST, など) を設定します。この属性が指定された場合、ボタンを所有するフォームmethod 属性より優先されます。
formnovalidate {{ HTMLElement("button") }}, {{ HTMLElement("input") }} button や input が送信ボタンである場合 (type="submit")、この論理属性はフォームが送信時に検証されないことを指定します。この属性が指定された場合、ボタンを所有するフォームnovalidate 属性より優先されます。
formtarget {{ HTMLElement("button") }}, {{ HTMLElement("input") }} button や input が送信ボタンである場合 (type="submit")、この属性はフォームを送信した後で受け取るレスポンスを表示する閲覧コンテキスト (例えば、タブ、ウィンドウ、インラインフレーム) を指定します。この属性が指定された場合、ボタンを所有するフォームtarget 属性より優先されます。
headers {{ HTMLElement("td") }}, {{ HTMLElement("th") }} この要素に適用する <th> 要素の ID。
height {{ HTMLElement("canvas") }}, {{ HTMLElement("embed") }}, {{ HTMLElement("iframe") }}, {{ HTMLElement("img") }}, {{ HTMLElement("input") }}, {{ HTMLElement("object") }}, {{ HTMLElement("video") }}

ここに挙げた要素の高さを指定します。他の要素では、 {{cssxref("height")}} プロパティを使用してください。

注: {{HTMLElement("div")}} など一部の要素では、これは古い属性であり、代わりに CSS の {{Cssxref("height")}} プロパティを使用してください。

hidden グローバル属性 この要素のレンダリングを抑制しますが、 script 要素などの子要素は有効なままにします。
high {{ HTMLElement("meter") }} 最大値の下限を示します。
href {{ HTMLElement("a") }}, {{ HTMLElement("area") }}, {{ HTMLElement("base") }}, {{ HTMLElement("link") }} リンクされたリソースの URL です。
hreflang {{ HTMLElement("a") }}, {{ HTMLElement("area") }}, {{ HTMLElement("link") }} リンクされたリソースの言語を指定します。
http-equiv {{ HTMLElement("meta") }} プラグマディレクティブを定義します。
icon {{ HTMLElement("command") }} コマンドを表す画像を指定します。
id グローバル属性 特定の要素へスタイルを設定するために CSS と共によく使われます。この属性の値は一意でなければなりません。
importance {{experimental_inline}} {{ HTMLElement("iframe") }}, {{ HTMLElement("img") }}, {{ HTMLElement("link") }}, {{ HTMLElement("script") }} リソースの相対的なフェッチ優先順位を示します。
integrity {{ HTMLElement("link") }}, {{ HTMLElement("script") }}

ブラウザーが読み込むものを検証できるようにするためのサブリソース完全性の値を指定します。

intrinsicsize {{deprecated_inline}} {{ HTMLElement("img") }} この属性はブラウザーに、画像に固有の実際の寸法を無視して、属性で指定された寸法を割り当てるように指示します。
inputmode {{ HTMLElement("textarea") }}, contenteditable 要素やその内容を編集する際に、ユーザーが入力する可能性のあるデータの種類のヒントを提供します。この属性はフォームコントロール (textarea 要素の値など) と共に、または編集対象となっている要素 (例えば contenteditable 属性の使用など) の中で使用することができます。
ismap {{ HTMLElement("img") }} 画像がサーバーサイドイメージマップの一部であることを示します。
itemprop グローバル属性
keytype {{ HTMLElement("keygen") }} 生成する鍵の種類を指定します。
kind {{ HTMLElement("track") }} テキストトラックの種類を指定します。
label {{ HTMLElement("optgroup") }}, {{ HTMLElement("option") }}, {{ HTMLElement("track") }} ユーザーが読める形の要素のタイトルを指定します。
lang グローバル属性 要素内で用いられている言語を定義します。
language {{deprecated_inline}} {{ HTMLElement("script") }} 要素で使用しているスクリプト言語を定義します。
loading {{experimental_inline}} {{ HTMLElement("img") }}, {{ HTMLElement("iframe") }} 要素を遅延読み込みさせたいか (loading="lazy") または直ちに読み込ませたいか (loading="eager") を示します。
list {{ HTMLElement("input") }} ユーザに提案するため、事前に定義した選択肢のリストを示す。
loop {{ HTMLElement("audio") }}, {{ HTMLElement("bgsound") }}, {{ HTMLElement("marquee") }}, {{ HTMLElement("video") }} メディアの再生が完了した後、始めから再生を開始するかを示します。
low {{ HTMLElement("meter") }} 最小値の上限を示します。
manifest {{deprecated_inline}} {{ HTMLElement("html") }} この文書のキャッシュマニフェストの URL を指定します。

注: この属性は廃止されており、代わりに <link rel="manifest"> を使用してください。

max {{ HTMLElement("input") }}, {{ HTMLElement("meter") }}, {{ HTMLElement("progress") }} 許容される最大の値を示します。
maxlength {{ HTMLElement("input") }}, {{ HTMLElement("textarea") }} 要素が許容する最大文字数を定義します。
minlength {{ HTMLElement("input") }}, {{ HTMLElement("textarea") }} 要素が許容する最小文字数を定義します。
media {{ HTMLElement("a") }}, {{ HTMLElement("area") }}, {{ HTMLElement("link") }}, {{ HTMLElement("source") }}, {{ HTMLElement("style") }} リンクされたリソースがどのメディアに対して設計されたかを指定します。
method {{ HTMLElement("form") }} フォームを送信する際に使用する HTTP メソッドを定義します。 GET (既定値) または POST が指定可能です。
min {{ HTMLElement("input") }}, {{ HTMLElement("meter") }} 許容される最小の値を示します。
multiple {{ HTMLElement("input") }}, {{ HTMLElement("select") }} input で type が email または file の input ものでは、複数の値を入力可能かどうかを示します。
muted {{ HTMLElement("audio") }}, {{ HTMLElement("video") }} ページ読み込み時に音声を無音にするかどうかを示します。
name {{ HTMLElement("button") }}, {{ HTMLElement("form") }}, {{ HTMLElement("fieldset") }}, {{ HTMLElement("iframe") }}, {{ HTMLElement("input") }}, {{ HTMLElement("keygen") }}, {{ HTMLElement("object") }}, {{ HTMLElement("output") }}, {{ HTMLElement("select") }}, {{ HTMLElement("textarea") }}, {{ HTMLElement("map") }}, {{ HTMLElement("meta") }}, {{ HTMLElement("param") }} 要素の名前です。例えば、送信されたフォームでサーバーがフィールドを識別するために使用します。
novalidate {{ HTMLElement("form") }} 送信時にフォームが検証しないことを示す属性です。
open {{ HTMLElement("details") }}, {{ HTMLElement("dialog") }} コンテンツが現在表示されているか(<details> 要素の場合)、ダイアログがアクティブで対話可能か(<dialog> 要素の場合)を示します。
optimum {{ HTMLElement("meter") }} 最適な値を示します。
pattern {{ HTMLElement("input") }} 要素の値を検証するための正規表現を定義します。
ping {{ HTMLElement("a") }}, {{ HTMLElement("area") }} ping 属性は、ユーザーがハイパーリンクをたどる場合に通知される URL のリストを空白区切りで指定します。
placeholder {{ HTMLElement("input") }}, {{ HTMLElement("textarea") }} フィールドが何を入力するものであるかのヒントを閲覧者に対し提供します。
poster {{ HTMLElement("video") }} ユーザが再生やシークを行うまでの間に表示するポスターフレームの URL です。
preload {{ HTMLElement("audio") }}, {{ HTMLElement("video") }} リソースの全体または一部の先読みを行う、あるいは先読みを行わないことを示す。
radiogroup {{ HTMLElement("command") }}
readonly {{ HTMLElement("input") }}, {{ HTMLElement("textarea") }} 要素が編集できるかどうかを示す。
referrerpolicy {{ HTMLElement("a") }}, {{ HTMLElement("area") }}, {{ HTMLElement("iframe") }}, {{ HTMLElement("img") }}, {{ HTMLElement("link") }}, {{ HTMLElement("script") }} リソースにアクセスする際にどのリファラーが送信されるかを指定します。
rel {{ HTMLElement("a") }}, {{ HTMLElement("area") }}, {{ HTMLElement("link") }} リンク先オブジェクトとリンク元オブジェクトとの関係を指定します。
required {{ HTMLElement("input") }}, {{ HTMLElement("select") }}, {{ HTMLElement("textarea") }} 入力が必須の要素であるかを示します。
reversed {{ HTMLElement("ol") }} リストを昇順ではなく降順に表示することを示します。
rows {{ HTMLElement("textarea") }} textarea の行数を定義します。
rowspan {{ HTMLElement("td") }}, {{ HTMLElement("th") }} テーブルセルがまたがる行数を定義します。
sandbox {{ HTMLElement("iframe") }} iframe に読み込まれた文書で特定の機能 (フォームの投稿や新しいウィンドウを開くなど) を使用するのを阻止します。
scope {{ HTMLElement("th") }} (th 要素で定義される) ヘッダーが関連するセルを定義します。
scoped {{non-standard_inline}} {{deprecated_inline}} {{ HTMLElement("style") }}
selected {{ HTMLElement("option") }} ページ読込時に、対象要素を選択状態にします。
shape {{ HTMLElement("a") }}, {{ HTMLElement("area") }}
size {{ HTMLElement("input") }}, {{ HTMLElement("select") }} 要素の幅を(ピクセル数で)定義します。要素の type 属性が text または password である場合は文字数になります。
sizes {{ HTMLElement("link") }}, {{ HTMLElement("img") }}, {{ HTMLElement("source") }}
slot グローバル属性 要素にシャドウ DOM のシャドウツリーのスロットを割り当てます。
span {{ HTMLElement("col") }}, {{ HTMLElement("colgroup") }}
spellcheck グローバル属性 要素のスペルチェックを有効にするかどうかを示します。
src {{ HTMLElement("audio") }}, {{ HTMLElement("embed") }}, {{ HTMLElement("iframe") }}, {{ HTMLElement("img") }}, {{ HTMLElement("input") }}, {{ HTMLElement("script") }}, {{ HTMLElement("source") }}, {{ HTMLElement("track") }}, {{ HTMLElement("video") }} 埋め込みコンテンツの URL です。
srcdoc {{ HTMLElement("iframe") }}
srclang {{ HTMLElement("track") }}
srcset {{ HTMLElement("img") }}, {{ HTMLElement("source") }} 一つ以上のレスポンシブ画像の候補です。
start {{ HTMLElement("ol") }} 1以外から始まる場合の最初の値を定義します。
step {{ HTMLElement("input") }}
style グローバル属性 外部スタイルシートや style 要素内に記述されたものより優先度の高いスタイル情報を記述します。
summary {{deprecated_inline}} {{ HTMLElement("table") }}
tabindex グローバル属性 ブラウザーによる既定のタブ順を無効化して、指定した順序に従うようにします。
target {{ HTMLElement("a") }}, {{ HTMLElement("area") }}, {{ HTMLElement("base") }}, {{ HTMLElement("form") }} リンク先の文書を開く場所(<a> 要素の場合)、または受信したレスポンスを表示する場所(<form>要素の場合)を指定します。
title グローバル属性 この要素にポインターを当てたときに表示されるツールチップのテキストです。
translate グローバル属性 ページが翻訳版である場合、要素の属性値と子の Text ノードが翻訳されているか、変更せずにそのままであるかを指定します。
type {{ HTMLElement("button") }}, {{ HTMLElement("input") }}, {{ HTMLElement("command") }}, {{ HTMLElement("embed") }}, {{ HTMLElement("object") }}, {{ HTMLElement("script") }}, {{ HTMLElement("source") }}, {{ HTMLElement("style") }}, {{ HTMLElement("menu") }}, {{ HTMLElement("link") }} 要素の型を定義します。
usemap {{ HTMLElement("img") }}, {{ HTMLElement("input") }}, {{ HTMLElement("object") }}
value {{ HTMLElement("button") }}, {{ HTMLElement("data") }}, {{ HTMLElement("input") }}, {{ HTMLElement("li") }}, {{ HTMLElement("meter") }}, {{ HTMLElement("option") }}, {{ HTMLElement("progress") }}, {{ HTMLElement("param") }} ページ読み込み時に要素で表示する既定値を定義します。
width {{ HTMLElement("canvas") }}, {{ HTMLElement("embed") }}, {{ HTMLElement("iframe") }}, {{ HTMLElement("img") }}, {{ HTMLElement("input") }}, {{ HTMLElement("object") }}, {{ HTMLElement("video") }}

ここに挙げられた要素に対して、要素の幅を指定します。

注: {{ HTMLElement("div") }} をはじめとする他の要素については、これは古い属性であり、代わりに CSS の {{ Cssxref("width") }} プロパティを使用してください。

wrap {{ HTMLElement("textarea") }} テキストを折り返すかどうかを示します。
## コンテンツ属性と IDL 属性 HTML では、ほとんどの属性に **コンテンツ属性** と **IDL (Interface Definition Language) 属性** の 2 つの側面があります。 コンテンツ属性はコンテンツ (HTML コード) から設定する属性であり、 {{domxref("element.setAttribute()")}} や {{domxref("element.getAttribute()")}} を使用して設定または取得できます。 コンテンツ属性は値として数値を想定するものであっても、常に文字列です。例えば コンテンツ属性を使用して {{HTMLElement("input")}} 要素の `maxlength` 属性に 42 を設定するには、その要素で `setAttribute("maxlength", "42")` を呼び出さなければなりません。 IDL 属性は JavaScript プロパティとしても知られています。これらは JavaScript プロパティを使用して、 `element.foo` のように読み書きします。IDL 属性は読み取り時に値を返すため基になるコンテンツ属性を使用したり(ただし、)、書き込み時に コンテンツ属性へ何らかの値を保存したりします。言い換えると、IDL 属性は コンテンツ属性を映し出します。 ほとんどの場合、IDL 属性は実際に使用する値として自身の値を返します。例えば {{HTMLElement("input")}} 要素の `type` 属性のデフォルト値は "text" であるので、`input.type="foobar"` を設定すると `<input>` 要素は (外見と動作が) text タイプになりますが、"type" コンテンツ属性の値は "foobar" になります。しかし、`type` IDL 属性は文字列 "text" を返します。 IDL 属性は常に文字列とは限りません。例えば `input.maxlength` は数値 (符号付き long) です。IDL 属性を使用するときは望ましい型の値を読み書きするので、`input.maxlength` は常に数値を返し、また `input.maxlength` を設定するときは数値を要求します。他の型で渡すと、標準的な JavaScript の型変換規則に従って自動的に数値へ変換されます。 IDL 属性は符号なし long、URL、論理値など[他の型を反映する](https://www.whatwg.org/specs/web-apps/current-work/multipage/urls.html#reflecting-content-attributes-in-idl-attributes)ことが可能です。残念ながら、 IDL 属性がコンテンツ属性と 属性に応じて IDL 属性が対応するコンテンツ属性と一体化して動作するための明確な規則や方法はありません。ほとんどの場合は[仕様書にあるレイアウトルール](https://www.whatwg.org/specs/web-apps/current-work/multipage/urls.html#reflecting-content-attributes-in-idl-attributes)に従いますが、そうでない場合もあります。 HTML 仕様では可能な限り開発者にやさしいものにしようとしていますが、さまざまな理由 (たいていは歴史的な理由) により奇妙な動作になる属性 (例えば `select.size`) があり、実際どのように動作するかを理解するために仕様書を読むようにしましょう。 ## 論理属性 一部のコンテンツ属性 (例えば `required`, `readonly`, `disabled`) は[論理属性](https://www.w3.org/TR/html52/infrastructure.html#sec-boolean-attributes) (boolean attributes) と呼ばれています。論理属性は存在すれば、その値が **true** となり、存在しなければ、その値が **false** となります。 HTML5 では、論理属性に許されている値の制約を定義しています。属性が存在する場合は、値は空文字列 (属性の値が割り当てられないことがあります) または属性の正式名に ASCII で大文字・小文字まで一致する値のどちらかで、前後にホワイトスペースを含んではいけません。以下の例は論理属性をマークアップする正しい方法です。
This is valid HTML but invalid XML.
This is also valid HTML but invalid XML.
This is valid HTML and also valid XML.
This is also valid HTML and XML, but perhaps a bit verbose.
明確にするために、 "`true`" および "`false`" という値は論理属性では許可されていません。偽の値を表すには、属性ごと省略する必要があります。この制約により、いくつかのよくある誤解が明確になります。例えば `checked="false"` は、属性が存在するため、その要素の `checked` 属性が **true** であると解釈されます。 ## 関連情報 - [HTML 要素](/ja/docs/Web/HTML/Element)