54
53

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

【CSS】<input type="file">は::file-selector-buttonでスタイルをつけよう

Posted at

<input type="file">は直接スタイル指定ができず、デザインの変更
が面倒だったのですが、::file-selector-button を使えば簡単に指定できることを知ったので備忘録です。

使い方

See the Pen ::file-selector-button by himeka223 (@himeka223) on CodePen.

::file-selector-button にボタンのスタイルを設定するだけです!

  • 「選択されていません(選択後はファイル名)」の文言のスタイルはinputの方で変更できます。
  • display: block; を追加すればボタンとテキストの間で改行も可能です。

すべてのブラウザで対応済み

既にすべてのブラウザで対応済みのようで、安心して使えます!

image.png

テキストも変更したい場合は疑似要素をのせる

残念ながら ::file-selector-button ではテキストは変えることができません。::file-selector-button は見えなくして、同じサイズの ::before または ::after にボタンのスタイルを指定して、文字をのせるしかなさそうです。

See the Pen ::file-selector-button(テキストも変更したいとき) by himeka223 (@himeka223) on CodePen.

ドロップエリアについて

デフォルトで「ファイル選択」ボタンにドロップすることが可能です。
なので<input type="file">自体にドロップエリアのスタイルを指定するだけでドロップエリアが作成できます。

See the Pen Untitled by himeka223 (@himeka223) on CodePen.

注意:サイズを固定しないと中央寄せはできない

ボタンのデザイン、テキストもなんとか変更はできました。
いろいろ試したけど、サイズを固定せずに、ファイル名の長さに関係なく中央寄せすることは不可能でした…。
あまりこだわったデザインは避けるべきだなと思いました。

54
53
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
54
53

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?