cssで三角形を表示する方法

画像を使わずに、cssでスタイルを指定するだけで三角形を表示させる方法を紹介します。

三角形を表示させるにはborder(枠線)を使用します。

なぜborderで三角形を作れるのか、まずはその説明をします。

borderの仕組み

以下のように、上下左右に太さ10pxのborderを指定した要素を表示します。

.sample1{
  border: solid 10px blue;
}

以下のように表示されます。

この時、上下の色だけ赤にしたい場合、以下のようにしても、うまくいきません。

.sample2{
  border: solid 10px blue;
  border-top: solid 10px red;
  border-bottom: solid 10px red;
}

以下のように表示されます。

なぜなら、縦と横が重なる部分は、どちらかのスタイル(青か赤)を優先させてしまうわけにはいかないので、斜めで境界となるように表示されます。

この仕様を逆にうまく利用することにより、三角形を作成することができます。

三角形の表示方法

上記の例を、今度は要素を空(高さ0)にして表示させると以下のように表示されます。

左右に青い三角形が表示できました。

同様に、横幅0で表示させると、上下に赤い三角形が表示されます。

よく見かけるサンプルでは、擬似要素を使用することが多いです。

例えば、ある要素に下向きの三角形をくっつけて、吹き出しのように表示させたりします。

htmlでは以下のように定義して、

<div class="sample3">
  sample3
</div>

cssでは以下のように定義します。

.sample3{
  /*三角形で絶対位置を指定するためにpositionを指定します*/
  position: relative;

  /*要素自身のスタイルを指定します*/
  padding: 5px;
  border-radius: 5px;
  color: white;
  background-color: blue;
}
.sample3::before{
  /*三角形を表示させるため、要素は空(高さ0、横幅0)にします*/
  content: "";

  /*三角形を表示させる位置を指定します*/
  position: absolute;
  top: 97%;
  left: 20px;

  /*borderで三角形を表示させます*/
  /*上部分以外は透明にすることにより、下向きの三角形を表示します*/
  border: 6px solid transparent;
  border-top: 6px solid blue;
}

以下のように表示されます。


関連記事

  • cssだけでホバー時にバルーンポップアップを表示させる

    javascriptを使わず、cssだけでマウスホバー時に、バルーンポップアップを表示させる方法を紹介します。完成形は以下のようなイメージです。最初に完成形のcssを記載します。cssはjavascr...


  • less|cssに変数を使い実装を効率化する方法

    ホームページを作っていて、規模が大きくなっていくにつれ、気をつけていてもcssのソースはグチャグチャになってしまい、後で見返したときに「これはどこのスタイルだっけ?」となってしまうことがあると思います...


  • html5 marginとpaddingで余白を設定する

    htmlで余白の設定をするときは、marginとpaddingのスタイルを使用します。例えば、以下のように色を分けて表示しても、要素どうしがくっついてしまい、わかりづらくなってしまいますので、余白を設...


  • html5 classを使って同じstyleをまとめる

    スタイルを各要素の中にたくさん書くとわかりづらくなってしまいます。以下のように、同じスタイルを複数の箇所に記載しているときは、classを使えば同じスタイルを1箇所にまとめることができます。クラスはh...


  • html5 ブロック要素とインライン要素を理解する

    htmlの要素には大きく分けてブロック要素とインライン要素があります。今回はこの2つの要素の違いについて説明します。例えば以下のhtmlで、トマトについての説明の箇所の背景色を赤、ピーマンについての説...


  • html5 ボーダーのスタイルで罫線を表示する

    pタグとh1タグの段落と見出しで読みやすい文章構成を作成する方法は段落と見出しを表示して、見た目をわかりやすくしました。今回は罫線を引いて、より見た目をわかりやすくする方法を紹介します。文字色を変える...


  • pタグとh1タグの段落と見出しで読みやすい文章構成を作成する方法

    前回ホームページ入門・初心者向け html5の基本的な文法までで、htmlをブラウザで表示することができるようになりました。今回からは、実際にhtmlでのいろいろな表現方法を紹介していき、最終的にはき...


  • ホームページ入門・初心者向け html5の基本的な文法

    前回初めてのホームページ作成のためのhtmlの基本でホームページの作成にあたって、「htmlとは何か?」ということを説明しました。今回は、実際にhtmlをどのように書いていくのか説明します。※この記事...


  • 初めてのホームページ作成のためのhtmlの基本

    プログラミングの経験もなく、初めてホームページを作成しようと考えている人に向けて、htmlの基本を数回に分けて説明します。予備知識としてホームページの基本的な仕組みと考え方でホームページの基本的な仕組...


  • canvasでグラデーションを表現する

    canvasのアニメーションで軌跡・残像・フェードアウトを表現するまではいろいろな図形を描画したり、描画した図形を動かしてアニメーションを表現する方法を紹介しました。今回は単色だけでなく、グラデーショ...