0%

Programmingプログラミングナレッジ

Posted:2017.11.24

input=”file”要素のデザインをフルカスタマイズする

HTMLのフォーム要素ですが、ウェブサイトなどではよくデザインが変更されているものを見かけます。基本的にはこれらフォーム要素を直接デザインするのもあれば、要素自体は非表示にして対応するlabel要素に対してデザインするという場合もあります。

 

ただしfile要素についてはなかなかクセがあるのでデザイン変更には少し複雑な方法となります。今回はCSSとjQueryを使ってこのfile要素のデザインをフルカスタマイズする方法を見ていきたいと思います。

 

まずはHTMLからコードを見ていきます。input要素自体を囲うラッパー要素を用意し、その中にinput要素とlabel要素を入れておきます。この時input要素とlabel要素が対応するようにid属性とfor属性で紐づけておきます。

【HTML】※一部抜粋

<div id="input-group">
  <input type="file" id="01" name="01"><label for="01" id="input-label">ファイルを選択してください</label>
</div>

 

次にCSSでinput要素を非表示にして、label要素を修飾していきます。ポイントとなるのは、labelの擬似要素でステータスを示す文字を表示させるのと、アップロードした時に表示されるファイル名の要素のスタイルもつけておきます。

【CSS】

input[type="file"] {
   display: none;
}
label {
   background: #ddd;
   padding: 10px 30px;
   border-radius: 10px;
   display: inline-block;
   position: relative;
}
label::after {
   content: "選択されていません";
   font-size: 14px;
   height: 20px;
   line-height: 20px;
   position: absolute;
   right: -140px;
   top: calc(50% - 10px);
}
label.changed::after {
   content: "";
}
.filename {
   font-size: 12px;
}

 

最後にjQueryで切り替えなどの動きの部分を実装していきます。input要素に対して状態が変わるchangeイベントで設定し、セットされたファイル名をファイルの情報として配列から取得します。そしてlabel要素にファイルがセットされた状態を示すclass名を追加し、先ほど取得したファイル名のテキストが入った要素を生成します。

【javascript】

$(function(){
  $("input[type='file']").on('change',function(){
     var file = $(this).prop('files')[0];
     if(!($(".filename").length)){
       $("#input-group").append('<span class="filename"></span>');
     }
     $("#input-label").addClass('changed');
     $(".filename").html(file.name);
   });
 });

 

少し複雑ですがこれでinputのfile要素のデザインが自由にカスタマイズできます。今回のサンプルはこちらにあげておりますので、ぜひ試してみてください。

author
この記事を書いた人オガワ シンヤ
FacebookTwitter

DesignSupply.代表 / ディレクター・ウェブデザイナー・フロントエンドエンジニアをやっています。「ウェブとデザインでヒト・モノ・サービスを繋げ新しい価値を生み出す」をコンセプトに日々奮闘中!制作中はチョコレートが欠かせない三十路Webクリエイター。

制作のご依頼やお問い合わせ・パートナー業務提携のご相談はこちら

デザインやウェブ制作についてのご依頼やご相談、その他お問い合わせなどもお気軽にご連絡ください。フットワークの軽さやレスポンスの早さ、また豊富な経験や知識、技術を活かした対応力といったフリーランスクリエイターの強みでクライアント様、パートナー企業様のお力になります。デザインからコーディングやWordPress実装といったウェブサイト構築はもちろん、写真撮影や動画編集、コンテンツ制作からサイト運用サポートまで一括してお任せください。

ホームページ制作のご検討やウェブ運用でお悩みの経営者様や企業のウェブ担当者様をはじめ、個人で店舗を営んでいらっしゃるオーナー様、フリーで活動されているビジネスオーナー様はもちろんのこと、リソース不足でお困りの制作会社様、またクリエイターをお探しの代理店様も大歓迎です。

コンタクトをご希望の方はお手数ですが、下記よりお問い合わせフォームのページへアクセスしていただき、必要事項を入力の上メッセージを送信してください。確認でき次第すぐに折り返しご連絡致します。

コメントもお気軽にどうぞ

記事に関するご質問やご意見などありましたら下記のコメントフォームよりお気軽に投稿ください。なおメールアドレスは公開されませんのでご安心ください。また、* が付いている欄は必須項目となります。

内容に問題なければ、下記の「コメントを送信する」ボタンを押してください。

CAPTCHA


ページトップへ
大阪市天王寺区のホームページ制作デザイン事務所(SOHO)DesignSupply.【デザインサプライ】