ナビゲーションバーがあり、ボタンはホバー状態ですが、それぞれのページで「アクティブ」である必要があります。このナビゲーションバーはインクルードの一部であるため、のように、bodyタグのクラスを介してアクティブ状態を実行することにしました.dashboard .dashboard-button
。だから私はホバーとこれを持っています。
私はSass/Compassでこれを行うための最も合理化された方法を見つけようとしていました。いくつかのミックスインを作成しました。
@mixin nav-button-on($icon) {
background-color: #2f3684; // Old browsers
@include filter-gradient($offwhite, #E5E5E5, vertical); // IE6-9
@include background-image(url('../images/'+$icon+'-on.png'),linear-gradient(top, $offwhite 0%, #E5E5E5 100%));
border-bottom: $borderbottom solid #F31A35;
a { color: $red;}
}
@mixin nav-button($icon){
background-color: #fff; // Old browsers
@include filter-gradient(#fff, #fff, vertical); // IE6-9
@include background-image(url('../images/'+$icon+'.png'),linear-gradient(top, #fff 0%, #fff 100%));
}
そして、ボタンが定義されているLIで、私は
li {
&.dashboard {
@include nav-button('dashboard');
}
.dashboard &.dashboard {
@include nav-button-on('dashboard');
&:hover {
@include nav-button-on('dashboard');
}
}
}
HTML:
<body class="dashboard">
<div id="nav">
<ul>
<li class="first dashboard"><a href="/index.php">Dashboard</a></li>
<li class="challenges"><a href="/challenges.php">Challenges & Teams</a></li>
<li class="goals"><a href="/goals.php">Goals</a></li>
<li class="activity"><a href="/my-activity.php">My Activity</a></li>
<li class="destinations"><a href="/destinations.php">Destinations</a></li>
<li class="fitness last"><a href="/fitness-resources.php">Fitness Resources</a></li>
</ul>
</div>
これは少し複雑に思えますが、これを合理化するためのアドバイスはないかと思いました。
注:グラデーションのホバー状態で単色の背景にカーソルを合わせるとフラッシュが発生するため、白から白へのグラデーションを追加する必要がありました。