CSS Web制作

CSSのtext-shadowでテキスト(文字)に影をつける方法【サンプル付き】

2023年3月23日

※ 当サイトではアフィリエイト広告を利用しています

テキストに影をつける方法教えてくれる?

テキストを立体的に見えるようにドロップシャドウをつけることがあります。

ドロップシャドウとは『テキストや画像に影が落ちているような表現』になります。

それにはCSSのtext-shadowというプロパティを使いますが、

text-shadowは、

  • 方向
  • ぼかし具合

などいろいろと調整が可能です。

テキストに影をつけると立体的になるだけでなく、見やすくなります。

例えば当ブログのサムネイル右下にある更新日ですが、文字が白なので背景色も白だと影をつけないと見えなくなります。

text-shadow使用

text-shadow使用

このようにテキストを見えやすくしたり目立たせるときに使います。

それではtext-shadowとサンプルを使いながら解説していきます。

じゅんぺいブログは、Web制作コーディングWordPress制作)の技術記事を中心に、約500記事公開しています。ぜひ他の記事も参考にしてみてください!
完全無料のプログラミングスクール『ZeroPlus Gate』
30日間でWeb制作を学べる無料のプログラミングスクールがこちら
いきなり数十万するプログラミングスクールは厳しい・・・という人のお試しに最適です。
現在は無料ですがいつ有料になるか分からないので、気になる方はお早めに👇
(有料になっていたらすいません🙇‍♂️)

\ 完全無料 /

ZeroPlus Gate公式サイト

毎日先着制!

text-shadowでテキスト(文字)に影をつける方法

今回はtext-shadowというCSSのプロパティを使ってテキストに影を作ります。

これからいろいろなパターンをご紹介しますが、HTMLは共通でこちらになります。

<p>じゅんぺいブログ</p>

CSSの基本はこちらになります。

p {
  font-size: 30px;
  font-weight: 700;
  letter-spacing: .2em;
  line-height: 2;
  text-align: center;
}

これは影とは無関係なので無視してOKです。

text-shadowは以下のように指定できます。

例)
p {
  text-shadow: 3px 3px 5px #c0c0c0;
}

これはそれぞれの値を半角スペースで区切り、全部で4つの値を指定できます。

値の意味は左から順に以下のようになります。

p {
  text-shadow: ① ② ③ ④;
}
  1. 水平方向の影の位置 ※必須
  2. 垂直方向の影の位置 ※必須
  3. 影のぼかし具合
  4. 影の色

この中で必須なのは水平方向・垂直方向の位置だけですが、実質色も必須かと思います。

これを1つずつサンプルを使って解説していきます。

 

水平・垂直方向の位置

水平・垂直方向は必須になります。

まずはこのコードでサンプルを見てみます。

p {
  text-shadow: 5px 5px #c0c0c0;
}

これは『右に5px・下に5px』という意味で、色の解説はあとでしますが指定しないと見にくいのでここでも書いておきます。

See the Pen
text-shadow:基本
by junpei (@junpei-sugiyama)
on CodePen.

数値を大きくすれば位置も大きく動きます。

例えば以下のようにすると『右に10px・下に15px』になります。

p {
  text-shadow: 10px 15px #c0c0c0;
}

See the Pen
text-shadow:適用前
by junpei (@junpei-sugiyama)
on CodePen.

 

水平方向か垂直方向の片方だけ影をつける

水平方向か垂直方向の片方だけ影をつけたいときは、以下のように書きます。

/* 水平方向のみ */
p {
  text-shadow: 5px 0 #c0c0c0;
}
/* 垂直方向のみ */
p {
  text-shadow: 0 5px #c0c0c0;
}
/* これはNG(影は出ない) */
p {
  text-shadow: 5px #c0c0c0;
}

See the Pen
text-shadow:基本
by junpei (@junpei-sugiyama)
on CodePen.

 

右下ではなく左上にする

値をマイナスにすれば反対方向になります。

p {
  text-shadow: 5px 5px #c0c0c0; /* 右下 */
}
p {
  text-shadow: -5px -5px #c0c0c0; /* 左上 */
}

See the Pen
text-shadow:マイナスの値
by junpei (@junpei-sugiyama)
on CodePen.

もちろん右上・左下にも可能です。

 

影のぼかし具合

ここまでは影を一切ぼかしていませんが、以下のようにすると影をぼかすことが出来ます。

p {
  text-shadow: 5px 5px 4px #c0c0c0; /* 4pxがぼかし具合 */
}

See the Pen
text-shadow:ぼかす
by junpei (@junpei-sugiyama)
on CodePen.

 

影の色

影の色を指定しないと、影の色は文字色と同じになります。

/* 文字色も影も黒 */
p {
  color: black;
  text-shadow: 5px 5px 4px;
}
/* 文字色も影も緑 */
p {
  color: green;
  text-shadow: 5px 5px 4px;
}

See the Pen
text-shadow:文字色と影の色が同じ
by junpei (@junpei-sugiyama)
on CodePen.

しかし影の色を指定すれば、文字色と別の色にできます。

/* 文字色は黒、影はグレー */
p {
  color: black;
  text-shadow: 5px 5px 4px gray;
}
/* 文字色は緑、影はオレンジ */
p {
  color: green;
  text-shadow: 5px 5px 4px orange;
}

ぼかしは省略してカラーコードを書いてもOKです。

See the Pen
text-shadow:文字色と影の色が別
by junpei (@junpei-sugiyama)
on CodePen.

文字色と同じだと影は見えにくいので、必須ではありませんが基本的には書くようにした方がいいかと思います。

 

影を複数

text-shadowは複数つけることが可能です。

その場合カンマで区切って書けばOKです。

/* 影を2つ */
p {
  text-shadow: 3px 3px #ff8484, 6px 6px #7fbfff;
}
/* 影を3つ */
p {
  text-shadow: 3px 3px #ff3838, 6px 6px #389bff, 9px 9px #ff9b38;
}

複数書く場合は位置をズラさないと重なってしまうので、少しずつズラしましょう。

See the Pen
text-shadow:影を複数
by junpei (@junpei-sugiyama)
on CodePen.

 

影を全方向にして縁取り

影を複数つけるのを利用して、縁取り文字のようにできます。

例えば文字色が白で背景色も白だと当然見えなくなりますが、以下のように書くと縁取り文字のようになります。

/* 影を右下と左上 */
p {
  text-shadow: 3px 3px 5px #c0c0c0, -3px -3px 5px #c0c0c0;
}
/* 影を全方向 */
p {
  text-shadow: 3px 3px 5px #c0c0c0, -3px -3px 5px #c0c0c0, 3px -3px 5px #c0c0c0, -3px 3px 5px #c0c0c0;
}
/* 影を全方向(ぼかさない) */
p {
  text-shadow: 3px 3px #c0c0c0, -3px -3px #c0c0c0, 3px -3px #c0c0c0, -3px 3px #c0c0c0;
}
/* 位置はそのままでぼかすだけ */
p {
  text-shadow: 0 0 8px #555;
}

1つ目は右下と左上だけで、これでも縁取り文字のように見えますが、2つ目のように全方向に書くとより自然に見えるようになります。

ただし3つ目のようにぼかさないと、縁がギザギザになるのでご注意下さい。

あとは4つ目のように位置はそのままでぼかすだけにしても、縁取りのようになります。

See the Pen
text-shadow:影を全方向
by junpei (@junpei-sugiyama)
on CodePen.

まとめ

今回はtext-shadowでテキスト(文字)に影をつける方法を解説してきました。

box-shadowに比べて使う機会は少ないと思いますが、知っておくと便利かと思います。

以上になります。

この記事が役に立ったと思ったら、シェアボタンからX(旧Twitter)などにシェアすると、いいねされてフォロワーが増えたりすることがあるよ!

 

  • この記事を書いた人

じゅんぺい

37歳からWeb制作とブログ開始。Web制作歴5年目でコーディングとWordPressオリジナルテーマ制作が中心。これまで120件以上を納品。当ブログ月間最高15万PVで、370記事以上はWeb制作の技術記事。コンテンツ販売→累計売上1200万円&1500部超え。X(旧Twitter)フォロワー7200人以上。2024年3月からブログの経験を活かしてライターとしても活動を開始。

-CSS, Web制作