私が理解しているように、width/padding/marginプロパティはブロックレベルの要素に対してのみ機能します。しかし、INPUTとSELECT要素では、幅を指定することができます。これは動作します。すべき?INPUTとSELECT要素のカスタムサイズ
私はこのような何か書くことができます:
<input type="text" style="display:block;" />
をしかし、それは必要なのか?
誰でも理由を説明してください。
私が理解しているように、width/padding/marginプロパティはブロックレベルの要素に対してのみ機能します。しかし、INPUTとSELECT要素では、幅を指定することができます。これは動作します。すべき?INPUTとSELECT要素のカスタムサイズ
私はこのような何か書くことができます:
<input type="text" style="display:block;" />
をしかし、それは必要なのか?
誰でも理由を説明してください。
実際にはインライン要素ではなく、インラインブロック要素です。これにより、インライン要素の流れを壊すことなく、幅、高さ、および他のブロック固有のプロパティを指定することができます。 In good browsersあなたは同じことを達成するためにどの要素でも "display:inline-block"を使うことができます。
フォーム要素はHTML/CSS世界の黒い羊です。通常のHTML要素のように機能しない多くのプロパティがあります。
それはヨールの質問に答えていませんが、あなたは以下の議論は面白いかもしれません:http://meyerweb.com/eric/thoughts/2007/05/15/formal-weirdness/
は技術的には、それはブラウザ固有である演色性です。この時点では、ほとんどのブラウザで幅を設定できますが、特に古いブラウザでは保証されません。また、の場合はでバグが発生する可能性があります。
入力要素のW3仕様は、技術的にそれをインライン要素にします。インラインブロックはW3仕様の一部でもなく、CSS2の一部です(古いブラウザでは一貫性がありません)。
たとえば、幅をパーセントで指定し、テキストを大量に入れると面白いバグがあります。
長いストーリーは、ほとんど常に安全です。私が見た公式仕様の一部ではありません。
は適用:例えば入力として全ての要素が、非置換インライン要素、テーブルの行と行グループ
フォームコントロール、及び選択要素ははインラインで置換されています(要素はフォームコントロールに置き換えられます。テキストコンテンツは通常の要素のように表示されません)。
これらは置き換えられるため、置き換えられないため、widthプロパティが適用されます。
これは広範なテストではありませんが、少なくともFirefox 3では入力要素の計算されたスタイル(それを変更する著者スタイリングなし)はdisplay:inline - inline-blockではありません。 – Quentin
@David、はい、あなたは正しいですが、Mozillaが内部的に "display:-moz-inline-box"を使用すると仮定しています(私は何の証拠も見つけられませんでした)。私もいくつかのテストを行っており、IE8とChrome2はSELECT要素の "インラインブロック"を報告し、Opera9は "インライン"を報告しているようです。あなたの答えは正しいと思いますが、そのような要素に対しては "display:inline-block"とするのはかなり安全です。 –