Webサイトに「必ずある」と言っても過言ではない要素…
おぉ…ボタンよ…
昔はスキューモーフィズムなデザインのボタンを画像で配置していましたよね。
Web2.0なデザインのボタンが懐かしい…
フラットデザインが主流の今ではCSSでの装飾が当たり前となりました。
一見、実装が簡単そうに見えるボタンですが、実は奥が深いんですよ…
こんな経験ありませんか?
- ボタンの大きさのバリエーションが多い…
- ボタンの色のバリエーションが多い…
- アイコンの位置がバラバラ…
- アイコンが2つ配置…
- アイコンの種類が多い…
- アイコンの大きさがバラバラ…
というわけで、このような場面にも簡単に対応できる汎用的なボタンを作ってみようと思います!
仕様
以下項目が設定可能なボタンを作成する。
アイコンについてはアイコンフォントを利用します。
- タグ
- a
- button
- 横幅
- デフォルト幅(min-width)
- ラベルの幅
- 親要素の幅100%
- 高さ
- デフォルトの高さ(min-height)
- 小さいボタン
- 大きいボタン
- アイコンの位置
- 左端
- ラベルの左
- ラベルの右
- 右端
- アイコンの数
- 左端 or ラベルの左に1つ
- 右端 or ラベルの右に1つ
- アイコンの種類と大きさ
- CSSに記述することで設定可能
実装
HTMLのマークアップは以下となります。
ボタンの設定項目についてはdata属性を利用します。
index.html
<aclass="btn"href=""><span>ボタン</span></a><buttonclass="btn"type="button"><span>ボタン</span></button>
ボタンのベースとなるSassは以下となります。
- Sassの変数で以下を管理
- ボタンの上下のパディング
- ボタンの左右のパディング
- ボタンの最小幅
- ボタンの最小の高さ
- ボタンの最大幅
- アイコンについてはFont Awesomeを利用
btn.scss
$btn-vertical-padding:10px;$btn-horizontal-padding:20px;$btn-min-width:250px;$btn-min-hight:50px;$btn-max-width:400px;.btn{position:relative;display:inline-block;min-width:$btn-min-width;font-weight:700;color:#fff;text-align:center;text-decoration:none;cursor:pointer;background-color:#ca5673;border:0;border-radius:20px;outline:none;transition:background-color0.2sease-out;span{position:relative;display:flex;align-items:center;justify-content:center;min-height:$btn-min-hight;padding:$btn-vertical-padding$btn-horizontal-padding;padding-bottom:$btn-vertical-padding;text-align:center;&::before,&::after{font-family:"Font Awesome 5 Free";}}&:visited,&:active{color:#fff;}&:hover{background-color:#a7475f;}@media(max-width:559px){width:100%;min-width:auto;max-width:$btn-max-width;}}
横幅
横幅の設定はdata-btn-width属性に以下の値を設定します。
ただし、スマホ時には全て同じ幅になります。
- data-btn-width="auto"
- data-btn-width="fluid"
index.html
<!-- デフォルト幅 --><aclass="btn"href=""><span>ボタン</span></a><!-- ボタンのラベルの幅 --><aclass="btn"href=""data-btn-width="auto"><span>ボタン</span></a><!-- 親要素の幅100% --><aclass="btn"href=""data-btn-width="fluid"><span>ボタン</span></a>
btn.scss
.btn{// ボタンのラベルの幅&[data-btn-width="auto"]{min-width:auto;}// 親要素の幅100%&[data-btn-width="fluid"]{min-width:100%;}}
高さ
高さの設定はdata-btn-height属性に以下の値を設定します。
大きさのバリエーションがもっと欲しい場合はdata-btn-height属性の値を増やすことで対応可能です。
- data-btn-height="small"
- data-btn-height="large"
<!-- デフォルトの高さ --><aclass="btn"href=""><span>ボタン</span></a><!-- 小さいボタン --><aclass="btn"href=""data-btn-height="small"><span>ボタン</span></a><!-- 大きいボタン --><aclass="btn"href=""data-btn-height="large"><span>ボタン</span></a>
btn.scss
$btn-min-hight-small:40px;$btn-min-hight-large:60px;.btn{// 小さいボタン&[data-btn-height="small"]{span{min-height:$btn-min-hight-small;}}// 大きいボタン&[data-btn-height="large"]{span{min-height:$btn-min-hight-large;}}}
アイコンの位置
アイコンの位置はdata-btn-icon-の後に位置を指定したdata属性名で指定します。
data属性値で指定しないので注意してください。
- data-btn-icon-left="angle-right"
- data-btn-icon-before="angle-right"
- data-btn-icon-after="angle-right"
- data-btn-icon-right="angle-right"
<!-- 左端 --><aclass="btn"href=""data-btn-icon-left="angle-right"><span>ボタン</span></a><!-- ラベルの左 --><aclass="btn"href=""data-btn-icon-before="angle-right"><span>ボタン</span></a><!-- ラベルの右 --><aclass="btn"href=""data-btn-icon-after="angle-right"><span>ボタン</span></a><!-- 右端 --><aclass="btn"href=""data-btn-icon-right="angle-right"><span>ボタン</span></a>
btn.scss
.btn{// アイコン位置のベースとなる設定&[data-btn-icon-left]span,&[data-btn-icon-right]span{padding-right:calc(#{$btn-horizontal-padding}+1em);padding-left:calc(#{$btn-horizontal-padding}+1em);}&[data-btn-icon-left]span::before,&[data-btn-icon-right]span::after{position:absolute;top:50%;transform:translateY(-50%);}&[data-btn-icon-left]span::before{left:$btn-horizontal-padding;}&[data-btn-icon-right]span::after{right:$btn-horizontal-padding;}&[data-btn-icon-before]span::before{padding-right:0.3em;}&[data-btn-icon-after]span::after{padding-left:0.3em;}}
アイコンの種類
アイコンの種類はdata-btn-icon-xxxx属性の値で設定します。
- data-btn-icon-before="angle-right"
<!-- 右矢印アイコン --><aclass="btn"href=""data-btn-icon-before="angle-right"><span>ボタン</span></a>
以下は全ての位置(左端、ラベルの左、ラベルの右、右端)に表示させるように記述していますが、必要な位置だけ記述してください。
btn.scss
.btn{// 右矢印アイコン&[data-btn-icon-left="angle-right"]span::before,&[data-btn-icon-right="angle-right"]span::after,&[data-btn-icon-before="angle-right"]span::before,&[data-btn-icon-after="angle-right"]span::after{font-size:1.2em;font-weight:900;content:"\f105";}}