[CSS] 「ポイント1」みたいな装飾付きの見出しを画像なしで設置したい
やりたいこと
- 商品やサービスの紹介で「~の3つのポイント」みたいなコンテンツを用意することがあります
- 「ポイント1:~」みたいな見出しをつけて詳細を説明していきますが、この「ポイントn」を目立たせることで、ユーザーの目を引くと共に、「これは何個目のポイントについての説明なのか」が伝わりやすくなります
- こういった細かい装飾は画像で行うことが多いのですが、CSSだけでも十分に実現可能です
サンプルコード
html
<h2 class="point" data-num="1">俺より先に寝てはいけない</h2>
<h2 class="point" data-num="2">俺より後に起きてもいけない</h2>
<h2 class="point" data-num="3">めしは上手く作れ</h2>
<h2 class="point" data-num="4">いつもきれいでいろ</h2>
CSS
.point {
position: relative;
padding: 0px 0px 0px calc(60px + 0.5em);
margin: 30px 0px 0px;
}
.point::before,
.point::after {
position: absolute;
top: 50%;
left: 0px;
transform: translateY(-50%);
width: 60px;
height: 60px;
border-radius: 50%;
color: #fff;
text-align: center;
box-sizing: border-box;
}
.point::before {
padding: 0.75em 0px 0px;
background-color: #3388dd;
font-size: 14px;
content: "Point";
}
.point::after {
padding: 1.25em 0px 0px;
font-size: 20px;
content: attr(data-num);
}
仕組み、解説、補足など
- 何番目かの情報は、見出しにつけた「data-num」属性の値を「content: attr(data-num)」という書き方で表示しています
ご質問など受け付けています
記事の中でわかりにくかったところ、もっと知りたかったこと、間違っていることなど、何でもお気軽にご連絡ください。
ご連絡は下記フォームを利用いただくか、ツイッターアカウント@flat8migi宛てでもOKです。