<!doctype html><html lang="en"> <head> <meta charset="UTF-8"> <title>CSS制作立体导航</title> <link rel="stylesheet" href="http://www.w3cplus.com/demo/css3/base.css"> <style> body{ background: #ebebeb; } .nav{ width:560px; height: 50px; font:bold 0/50px Arial; text-align:center; margin:40px auto 0; background: #f65f57; /*制作导航圆角*/ border-radius: 8px; /*制作导航立体效果*/ box-shadow: 0 7px 0 #ba4a45; } .nav a{ display: inline-block; /* a元素的过渡属性:1、设置所有a标签过渡;2、过渡时间;3、速度曲线:以慢速开始的过渡效果 */ -webkit-transition: all 0.2s ease-in;/* Safari 和 Chrome */ -moz-transition: all 0.2s ease-in;/* Firefox */ -o-transition: all 0.2s ease-in;/* Opera */ -ms-transition: all 0.2s ease-in;/* IE 9 */ transition: all 0.2s ease-in; } .nav a:hover{ /* 鼠标移上时的效果;定义2D旋转10度 */ -webkit-transform:rotate(10deg); -moz-transform:rotate(10deg); -o-transform:rotate(10deg); -ms-transform:rotate(10deg); transform:rotate(10deg); } .nav li{ position:relative; display:inline-block; padding:0 16px; font-size: 14px; text-shadow:1px 2px 4px rgba(0,0,0,.5); list-style: none outside none; } /*制作导航分隔线效果*/ .nav li::before, .nav li::after{ content:""; position:absolute; top:14px; height: 25px; width: 1px; } .nav li::after{ right: 0; /* 线性渐变 */ background: -moz-linear-gradient(top, rgba(255,255,255,0), rgba(255,255,255,.2) 50%, rgba(255,255,255,0)); background: -webkit-linear-gradient(top, rgba(255,255,255,0), rgba(255,255,255,.2) 50%, rgba(255,255,255,0)); background: -o-linear-gradient(top, rgba(255,255,255,0), rgba(255,255,255,.2) 50%, rgba(255,255,255,0)); background: -ms-linear-gradient(top, rgba(255,255,255,0), rgba(255,255,255,.2) 50%, rgba(255,255,255,0)); background: linear-gradient(top, rgba(255,255,255,0), rgba(255,255,255,.2) 50%, rgba(255,255,255,0)); } .nav li::before{ left: 0; background: -moz-linear-gradient(top, #ff625a, #9e3e3a 50%, #ff625a); background: -webkit-linear-gradient(top, #ff625a, #9e3e3a 50%, #ff625a); background: -o-linear-gradient(top, #ff625a, #9e3e3a 50%, #ff625a); background: -ms-linear-gradient(top, #ff625a, #9e3e3a 50%, #ff625a); background: linear-gradient(top, #ff625a, #9e3e3a 50%, #ff625a); } /*删除导航第一个导航项左边的分隔线*/ .nav li:first-child::before{ background: none; } /*删除导航最后一个导航右边的分隔线*/ .nav li:last-child::after{ background: none; } .nav a, .nav a:hover{ color:#fff; text-decoration: none; } </style> </head> <body> <ul class="nav"> <li><a href="">首页</a></li> <li><a href="">个人简介</a></li> <li><a href="">作品集</a></li> <li><a href="">博客</a></li> <li><a href="">资源</a></li> <li><a href="">联系我</a></li> </ul> </body></html>
レンダリング:
1
2
概要:
1.ボディ部分に順序のないリストを使用します
(1)ホバー
移動します。マウスアップ効果いつ 。
(2)質問::beforeと:beforeの違い
おそらく質問が見つからないと思います。
CSS セレクターに関する w3c 仕様:
A pseudo-element は 2 つのコロン (::
) とその後に続く疑似要素の名前で構成されます。::
) followed by the name of the pseudo-element.
This ::
notation is introduced by the current document in order to establish a discrimination between pseudo-classes and pseudo-elements. For compatibility with existing style sheets, user agents must also accept the previous one-colon notation for pseudo-elements introduced in CSS levels 1 and 2 (namely, :first-line
, :first-letter
, :before
and :after
:: code> 表記は、疑似クラスと疑似要素の区別を確立するために現在のドキュメントで導入されました。既存のスタイル シートとの互換性を確保するために、ユーザー エージェントは、CSS レベルで導入された疑似要素に対する以前の 1 コロン表記も受け入れる必要があります。 1 および 2 (つまり、<code>:first-line
、:first-letter
、:before
、および :after
) . この互換性は、CSS レベル 3 で導入された新しい擬似要素には許可されません。簡単に言うと、擬似要素は二重コロンと擬似要素の名前で構成されます。二重コロンは、疑似クラスと疑似要素を区別するために現在の仕様で導入されました。ただし、ブラウザは、CSS3 で導入された新しい疑似要素をサポートする一方で、first-line、:first-letter、:before、:after などの既存の古い疑似要素の記述方法を同時にサポートする必要があります。単一のコロンを記述する古い方法はサポートされなくなりました。
これで、タイトルの質問に完全に答えることができます。:before など、CSS2 より前に存在した疑似要素については、単一コロンと二重コロン::beforeは同じ効果があります。
したがって、ウェブサイトが webkit、firefox、opera などのブラウザと互換性があるだけでよい場合、IE ブラウザと互換性がある必要がある場合は、疑似要素にダブル コロンの記述方法を使用することをお勧めします。 CSS2 のシングルコロン記述方法を使用する方が安全です。
以上がCSSを使用して3次元ナビゲーションバーを作成する方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。