Стилизация выпадающего меню Тезис с помощью CSS - PullRequest
0 голосов
/ 13 июня 2011

Я использую тему Wordpress Thesis, которая поставляется со стандартным выпадающим меню, которое я хочу превратить в двухуровневое горизонтальное меню. Я хотел бы, чтобы при нажатии на родительский элемент дочерние элементы этого родителя (но не другие дочерние элементы) были видны.

Структура выглядит так:

<ul class="menu"> 
<li class="tab tab-home"><a href="http://dirtydeals.org.uk">Home</a></li> 
<li class="tab tab-1 current-parent"><a href="http://dirtydeals.org.uk/about/"     title="About">About<!--[if gte IE 7]><!--></a><!--<![endif]--> 
<!--[if lte IE 6]><table><tr><td><![endif]--> 
<ul class="submenu submenu-1"> 
<li class="item item-1 current"><a href="http://dirtydeals.org.uk/about/subnavigation-    page/" title="Subnavigation page">Subnavigation page</a></li> 
<li class="item item-2"><a href="http://dirtydeals.org.uk/about/sub-page/" title="Sub-    page">Sub-page</a></li> 
</ul> 
<!--[if lte IE 6]></td></tr></table></a><![endif]--> 
</li> 
<li class="tab tab-2"><a href="http://dirtydeals.org.uk/action/"     title="action">action</a></li> 
<li class="tab tab-3"><a href="http://dirtydeals.org.uk/media/" title="Media">Media<!--[if gte IE 7]><!--></a><!--<![endif]--> 
<!--[if lte IE 6]><table><tr><td><![endif]--> 
<ul class="submenu submenu-1"> 
<li class="item item-3"><a href="http://dirtydeals.org.uk/media/sample-page-2/"     title="Sample Page">Blog</a></li> 
</ul> 
<!--[if lte IE 6]></td></tr></table></a><![endif]--> 
</li> 
</ul> 

У меня это работает достаточно хорошо, однако проблема в том, что я не могу найти способ конкретно нацелить дочерние элементы конкретно. Если я скрываю «Блог» при просмотре «О программе», то он также скрывает дочерние элементы «О программе» или скрывает все подменю при просмотре одного из дочерних элементов «О программе».

Вот мой CSS:

/*Remove the hover drop-down effect*/
.custom .menu ul { position: absolute; visibility: visible; list-style: none; z-    index: 110; }

/*No clears on this so we can make the submenu horizontal*/
.custom .menu ul li { clear: none; }

/*Styling the submenu*/


.custom ul.submenu {
margin: 0px 0 0 0;
}

.custom ul.submenu a {
font-size: 1.3em;
text-transform: uppercase;
padding-right: 10px;
}

.custom ul.menu li ul.submenu li.item {
display: inline;
}

.custom ul.menu li.current ul.submenu li.item {
display: inline;
}

.custom ul.menu li { border: 1px solid red; }


.custom ul.menu li ul.submenu li.item a {  }


/*Hacking the submenu to make children work when a subpage is viewed*/

.custom ul.menu li ul.submenu li.item a { display: inline; }
.custom ul.menu li ul.submenu li.item a { border: 1px solid yellow; }
.custom ul.menu li.current-parent ul.submenu { border: 1px solid blue;}
.custom ul.menu li.current-parent ul.submenu li.item a { border: 1px solid white; }

.custom ul.menu li.current ul.submenu {
background-color: #444444;
padding: 10px;
width: 500px;
}

.custom ul.menu li.current ul.submenu li.item {
display: inline;
white-space: nowrap;
}

.custom ul.menu li.current ul.submenu li.item  a {
background-color: transparent;
display: inline;
}   


.menu ul, .menu ul li {
width: 18em;
}


.custom ul.menu li.current ul.submenu li.item:after {
content: "/";
font-size: 14px;
}

.custom ul.menu li.current ul.submenu li:last-child:after {
content: "";
}

/*Annoyingly each individual submenu has to be positioned separately*/
.custom ul.menu li.current ul.submenu-1 {
position: absolute;
left: -110px;
}

Может ли кто-нибудь с более логичным умом и лучшим глазом взглянуть на меня, пожалуйста? Спасибо!

Страница находится здесь: http://dirtydeals.org.uk/about/subnavigation-page/

1 Ответ

0 голосов
/ 29 июля 2011

Этого легко добиться, используя условные теги из wordpress . Например, следующий код будет отображать «Блог», только если страница не «О»

<ul class="menu"> 
<li class="tab tab-home"><a href="http://dirtydeals.org.uk">Home</a></li> 
<li class="tab tab-1 current-parent"><a href="http://dirtydeals.org.uk/about/"     title="About">About<!--[if gte IE 7]><!--></a><!--<![endif]--> 
<!--[if lte IE 6]><table><tr><td><![endif]--> 
<ul class="submenu submenu-1"> 
<li class="item item-1 current"><a href="http://dirtydeals.org.uk/about/subnavigation-    page/" title="Subnavigation page">Subnavigation page</a></li> 
<li class="item item-2"><a href="http://dirtydeals.org.uk/about/sub-page/" title="Sub-    page">Sub-page</a></li> 
</ul> 
<!--[if lte IE 6]></td></tr></table></a><![endif]--> 
</li> 
<li class="tab tab-2"><a href="http://dirtydeals.org.uk/action/"     title="action">action</a></li> 
<li class="tab tab-3"><a href="http://dirtydeals.org.uk/media/" title="Media">Media<!--[if gte IE 7]><!--></a><!--<![endif]--> 
<!--[if lte IE 6]><table><tr><td><![endif]--> 
<ul class="submenu submenu-1"> 
<?php if ( !is_page('about') ) { ?>
<li class="item item-3"><a href="http://dirtydeals.org.uk/media/sample-page-2/"     title="Sample Page">Blog</a></li> 
<?php } ?>
</ul> 
<!--[if lte IE 6]></td></tr></table></a><![endif]--> 
...