Contributions

InfoBoxes (Category Index)
Search: 

'Category Box as Nested Unordered List for EZ(er) CSS & Dynamic menus v 1.00

This contribution is an alternate category box which will output your store's categories as a proper nested unordered list, instead of a collection of non-breaking spaces, quasi-bullets and break tags.

What's the big deal about that you ask? With the categories now output as an unordered list, you can now more easily apply a lot of nifty CSS to turn your category list into a horizontal drop-down or vertical fly-out menu, make it a collapsible menu, easily attach bullets, add cool mouseover effects, or just about anything you can dream up!

The advantage of this technique over pure javascript solutions is that it is much more flexible, easier to apply CSS trickery to, is more search-engine friendly and makes just one query to the database.

Output includes optional CSS class tags to mark categories as selected or as parent cats. You can also choose to render all of your categories (useful for dynamic menus) or to render only the root cats and the selected category tree. Note that this contribution merely provides a foundation for you to construct a more attractive/functional menu by providing a more semantically-correct output. A little CSS-magic is required on your end, though I have included a sample vertical flyout menu CSS. I have included some resources in the readme.

Expand All / Collapse All

Closing Tags Fix 2 27 Feb 2009

The fix by vampirehunter is incorrect.

On about line 196, it should read.

$output .= '</a>';

Not, $output .= '</a></li>';

ul_categories.php file and instructions for fix only.

Closing Tags Fix 26 Feb 2009
Version 1.1.2 (Fixed) 10 Jun 2008
Version 1.1.2 (Fixed) 10 Jun 2008
Version 1.1.2 10 Jun 2008
If using CSS 6 Jul 2007
updated with category levels 3 Mar 2007
Version 1.1 Bug fix and extras 2 May 2006
Forum Thread for Contribution 30 Apr 2006
'Category Box as Nested Unordered List for EZ(er) CSS & Dynamic menus v 1.00 30 Apr 2006

Note: Contributions are used at own risk.