職場の方がtext-decorationで波線をつけてるのを見て、「オーすごい」と思い、調べたら色んなことができたのでメモ。
まずは実際に見てみましょー。
これまでborder-bottomでなんとかしていたことが、text-decorationで出来ちゃいます(・o・)
IEを無視すればできちゃうんですね!IEを無視すればできちゃうんです!
各スタイル解説
01.普通の下線(underline)
data:image/s3,"s3://crabby-images/054d9/054d9b5d606fd8d7b92df19e1ca2d8b0d3b836a3" alt=""
text-decoration: underline;
言わずもがな。いつもの下線です。
参考リンク:MDN / text-decoration
02.取り消し線(line-through)
data:image/s3,"s3://crabby-images/ec244/ec244b03c2f347eb873bd32bd865915ce9f13de1" alt=""
text-decoration: line-through;
似たhtmlタグでdelがあるけど、そっちは明確に「削除する」意味があるときに使います。
delタグについてはこちらが参考になります。
参考リンク:MDN / text-decoration-line
03.色をつける(text-decoration-color)
data:image/s3,"s3://crabby-images/42659/4265939c9858fe3a460e6601e74455e182c0c7dd" alt=""
text-decoration-color: orange;
ショートハンド
text-decoration: underline orange;
なんと色もつけられます(知らなかった…)今までborder-bottomで指定してました(・o・)
参考リンク:MDN / text-decoration-color
04.太さを変える(text-decoration-thickness)
data:image/s3,"s3://crabby-images/7da9a/7da9af96ba14c23de065586cd6023e3c249e05d9" alt=""
text-decoration-thickness: 5px;
ショートハンド
text-decoration:underline 5px;
参考リンク:MDN / text-decoration-thickness
05〜08.二重線・点線・破線・波線(text-decoration-style)
data:image/s3,"s3://crabby-images/7695b/7695bdcd95ff3cb8014d8245bd70e6c34be425d6" alt=""
text-decoration-style: double;
text-decoration-style: dotted;
text-decoration-style: dashed;
text-decoration-style: wavy;
ショートハンド
text-decoration: underline double;
参考リンク:MDN / text-decoration-style
09〜10.上線
data:image/s3,"s3://crabby-images/45851/4585159b5df196b5b20b92459bc9fd224b178153" alt=""
text-decoration-line: overline;
下線だけでなく、上に線をつけることもできます。
下線、上線両方を指定することも可能。
text-decoration-line: underline overline;
参考リンク:MDN / text-decoration-line
11.文字と先の間に幅(text-underline-offset)
data:image/s3,"s3://crabby-images/5cfbe/5cfbe5bf933ae14f4539b0c3ea340a639326ffb3" alt=""
text-underline-offset: 15px;
テキストと線の間に余白を入れます。
text-underline-offset
はtext-decorationのショートハンドとしては使えず、個別に指定する必要があります。
参考リンク:MDN / text-underline-offset
12.線の引き方
data:image/s3,"s3://crabby-images/29b91/29b9100a82b39185ed16f66af2189ad8d68f19fa" alt=""
text-decoration-skip-ink: none;
日本語表記のときはあまり意味がありませんが、英語表記のときは違いが顕著です。デフォルトではautoになってます。
text-decoration-skip-ink
はtext-decorationのショートハンドとしては使えず、個別に指定する必要があります。
参考リンク:MDN / text-decoration-skip-ink
ショートハンドについて
一部のスタイルは「text-decoration」で一括指定できます。
例
data:image/s3,"s3://crabby-images/a971b/a971bc6593025b5d4640ad7b8a47d57209558fd1" alt=""
text-decoration: underline line-through overline;
data:image/s3,"s3://crabby-images/9d079/9d0799e1dccdb4574516d1224b710305a6af99e1" alt=""
text-decoration: underline orange 5px;
チートシート的Codepen
良さげなCodepenがあったのでメモ✍
参考リンク
CSSのtext-decorationは意外と色々なスタイル調整ができる
MDN:text-decoration ほか