[CSS]「:before」「:after」でタブのディテールを強化するスタイルシート
Post on:2011年5月16日
sponsorsr
画像を使用せずに、タブに広がったようなフレア状のボーダーを適用するスタイルシートを紹介します。

Flared Borders with CSS
デモページ
※上:ディテールを強化したタブ、下:旧式のタブ
[ad#ad-2]
対応ブラウザは「:before」「:after」はCSS2ですが、スタイルに角丸などのCSS3を使用しているため、CSS3対応ブラウザ(Firefox, Chrome, Safari, IE9)でご覧ください。
HTML
リスト要素を使用して、実装します。
<ul> <li class="current"><a href="#">Home</a></li> <li><a href="#">About</a></li> <li><a href="#">Products</a></li> <li><a href="#">Services</a></li> <li><a href="#">Contact</a></li> </ul>
CSS:タブのベース
シンプルな角丸を使用して、タブのベースとなる作成します。

html {
  background:#efefef;
}
body {
  margin:0;
  padding:0;
  color:#222;
  font:13px "Helvetica Neue", Helvetica, Arial, sans-serif;
}
ul {
  position:absolute;
  left:0;
  right:0;
  top:0;
  height:30px;
  background:#959DA5;
  border-bottom:1px solid #333;
  margin:0;
  padding:10px 16px 0;
  list-style:none;
}
ul li {
  float:left;
  margin:0 20px 0 0;
  padding:0;
}
ul a {
  display:block;
  color:#fff;
  text-decoration:none;
  padding:0 15px;
  line-height:29px;
  height:29px;
  font-weight:bold;
  background:#464646;
  border:1px solid #333;
  border-bottom:none;
  -webkit-font-smoothing:antialiased;
  -webkit-border-top-left-radius:8px;
  -webkit-border-top-right-radius:8px;
  -moz-border-radius:8px 8px 0 0;
  border-top-left-radius:8px;
  border-top-right-radius:8px;
  text-shadow:#000 0 -1px 0;
  /* This is to prevent jagged borders in Webkit. */ 
  -webkit-background-clip: padding-box;
}
ul li.current a {
  background:#efefef;
  color:#222;
  height:30px;
  text-shadow:#fff 0 1px 0;
  /* This is to prevent jagged borders in Webkit. */ 
  -webkit-background-clip: padding-box;
}
CSS:フレアのベース
次にタブの下にフレアの元となる形状を加えます。

ul li {
  position:relative;
}
ul li:before, ul li:after {
  content:'';
  width:9px;
  height:8px;
  position:absolute;
  z-index:2;
  bottom:0;
  background:#464646;
}
ul li:before {
  left:-8px;
}
ul li:after {
  right:-8px;
}
ul li.current:before, ul li.current:after {
  background:#efefef;
  bottom:0;
  -webkit-background-clip: padding-box;
}
[ad#ad-2]
CSS:タブをフレア状に
「:before」「:after」で加えたスタイルをフレア状にします。

ul a {
  position:relative;
}
ul a:before, ul a:after {
  content:'';
  width:10px;
  height:8px;
  position:absolute;
  z-index:3;
  bottom:-1px;
  background:#959DA5;
  overflow:hidden;
  border-bottom:1px solid #333;
  -webkit-background-clip: padding-box;
}
ul a:before {
  left:-11px;
  border-bottom-right-radius:8px;
  -webkit-border-bottom-right-radius:8px;
  -moz-border-radius-bottomright:8px;
  border-right:1px solid #222;
}
ul a:after {
  right:-11px;
  border-bottom-left-radius:8px;
  -webkit-border-bottom-left-radius:8px;
  -moz-border-radius-bottomleft:8px;
  border-left:1px solid #222;
}
ul li.current a:before, ul li.current a:after {
  bottom:0;
}
sponsors















