ファイルアップロードのinput type="file"にsize属性とwidthスタイルを適用してみたテスト

ファイルアップロードのinput要素の横幅の扱いが、各ブラウザで異なるようなので、まずは比べてみました。

概要

input要素は下記の4種類を比べてみました。

  1. size属性もwidthも無し。
  2. size="30"
  3. width:300px;
  4. size="30" と width:300px;

あ、size="30"とwidth:300px;は、別に同じ長さになるかとか確認してないです。

結果

下のほうに、スクリーンショットと、使用したhtmlソースコードがあります。


WebKit系のSafariChromeは、そもそもinput type="file"で生成されるUIが特殊です。
size="30"だと短すぎた可能性もありますが、widthは正しく反映されているような雰囲気です。


IE6とOperaは、割と期待通りの動きをしている気がします。
sizeが有効で、widthが設定されれば、さらにそれが適用されています。
widthの設定値より長くなるsize属性を併用したらどうなるかが気になりますね。


Firefoxは、このテストでは一番ダメな子で、widthは無視しています。
どうやらこれは昔からあるバグのようで、Firefox3ではまだ直っていないみたい。
先日でたFirefox3.5ではどうなんだろう。

さらに、size属性は有効ですが、なんとMacWindowsで長さの解釈が異なります。
スクリーンショットだと分かり難いですが、Mac Firefoxでのボタンを除いた入力欄の長さが、Windows Firefoxではボタンを含めた長さと同じになっています。
元々input要素へのsize属性は、ブラウザによってばらばらな事で有名ですが、同じブラウザなのに違うんですね。


Firefoxのバグについては、参考リンクを置いておきます。

MozillaZine.jp :: トピックを表示 - CSSのwidthでtype="file"の幅を指定することができない

CSSのwidthでtype="file"の幅を指定することができない。正確には場所は用意されてるっぽいんだけど、肝心のフォーム要素が伸びてくれない。Firefoxでtype="file"を伸ばすには、HTML側のsize属性に頼る必要がある。

Mac版Firefoxでは少し趣が違って、widthの指定は効く ...が、パス表示フィールドにのみ適用される。ちょっと込み入っているようなので、下記に纏めてみる。

widthの指定は効く ...が、表示上のサイズには影響しない
widthの指定は、「text-align: center;」の基準になっている
(60pxの<input type="text"&#8260;>と、60pxの<input type="file" &#8260;>を「text-align: center;」で並べた場合、左端が綺麗に揃う)
表示上のサイズは、size属性によって決定される
size属性の値は、パス表示フィールドに適用される
(size属性が同じ値の場合、Firefox-winの「パス表示フィールド+参照ボタン」と、Firefox-macの「パス表示フィールドの長さが等しい)
Firefox-macを考慮に入れる場合、size属性を少し小さめに入れる必要がある。ただしボックスを突き破ったからといって、レイアウトが崩れたりはしない(上に被さるか下に潜る)ようだ。Firefox-winを優先すべきだとは思うが、キツキツのデザインだとFirefox-macでボタンを押せなくなってまう事もあり、それは避けたいところ。
ROSS / Firefox / バグメモ

ソースコード

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="ja" lang="ja">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><!-- 京 -->
<title></title>
<meta name="Keywords" content="" />
<meta name="Description" content="" />
<meta http-equiv="Content-Style-Type" content="text/css" />
<meta http-equiv="Content-Script-Type" content="text/javascript" />
<style type="text/css" media="screen">
<!--
body{
  margin:0;
}
input{}
#boxRuler{
  width:300px;
}
  #boxRuler div{
    float:left;
    width:100px;
    font-size:10px;
    text-align:right;
    color:#fff;
  }
  #boxRuler #box100{
    background:#62BA5B;
  }
  #boxRuler #box200{
    background:#58954F;
  }
  #boxRuler #box300{
    background:#398133;
  }
  #boxRuler #box400{
    background:#1B4F1B;
  }
  #boxRuler #box500{
    background:#133800;
  }

.clearfix:after{
   content:url("");
   display:block;
   clear:both;
   height:0;
}
.clearfix{ display:inline-block; }
/* excludes MacIE5 \*/
* html .clearfix{ height:1%; }
.clearfix{ display:block; }
/* end MacIE5 */
 -->
</style>
<script type="text/javascript">
<!-- 
 -->
</script>
</head>
<body>
<div id="container">
  <div id="header">
    <div id="logo"></div><!-- id="logo" -->
  </div><!-- id="header" -->
  <div id="contents">
    <div id="main">
      
      <div id="boxRuler" class="clearfix"><div id="box100">100px</div><div id="box200">200px</div><div id="box300">300px</div></div>
      <form>
        
        <input type="file" /><br />
        <input type="file" size="30" /><br />
        <input type="file" style="width:300px;" /><br />
        <input type="file" size="30" style="width:300px;" />
        
      </form>
    </div><!-- id="main" -->
  </div><!-- id="contents" -->
</div><!-- id="container" -->
</body>
</html>