473,394 Members | 1,696 Online
Bytes | Software Development & Data Engineering Community
Post Job

Home Posts Topics Members FAQ

Join Bytes to post your question to a community of 473,394 software developers and data experts.

Side menu

Hi, I hope someone can help with this, it is driving me bonkers. After
reading the Suckerfish Dropdown article on A List Apart, I decided to try
and create a side menu based on the code I'd seen. Note that this is an
experiment and I'm only trying to get it to work in Firebird 0.7 at the
moment. Once it is working in Firebird, I'll look at adding any IE
workarounds, starting with those in the Dropdown article.

Here is the code I've got at the moment;

<html>
<head><title>Tester</title></head>
<style>

ul {
list-style: none; /* Remove list bullets */
background: #ddd; /* Grey background */
border: thin solid black; /* Menu border */
padding: 0; /* Remove bullet indent */
width: 7em; /* Force a thin menu */
}
li { /* Space out menu lines a bit more */
padding: 2px;
}

li > ul {
display: none; /* Hide sub menus */
width: auto;
position: absolute; /* Take sub menus out of the normal flow */
}

/* Show the sub elements for the top level item hovered over */
li:hover > ul {
display: inline; /* Display sub menu block on the same line as top level item */
}
li:hover {
background: #aaa; /* Darken the item we are on */
cursor: default; /* Retain a pointy arrow */
}

</style>
<body>
<ul class="top">
<li>Main item 1
<ul class="sub">
<li>
Sub1 Item1
<ul class="sub">
<li>Sub2 Item1</li>
<li>Sub2 Item2 a bit longer</li>
<li>Sub2 Item3</li>
</ul>
</li>
<li>
Sub1 Item2 a bit longer
<ul class="sub">
<li>Sub2 Item1</li>
<li>Sub2 Item2</li>
<li>Sub2 Item3 a bit longer</li>
</ul>
</li>
<li>Sub1 Item3</li>
</ul>
</li>
</ul>
</body>
</html>

When I just had the 'main' and 'sub1' stuff, everything looked fine.

Problems began when I added the sub2 items. Although the text seems OK,
the bordered background to the UL tag seems to be getting constrained by
the border of the higher level UL.

I've looked at the CSS2 specification, hunted around on various websites,
and tried random alteration and movement of various parts of the
stylesheet, but nothing seems to be helping. Can someone point me in the
right direction, or better yet solve the problem and then explain the
answer!

Many thanks in advance.

Jul 20 '05 #1
4 9170
Els
Simon Birch wrote:
Hi, I hope someone can help with this, it is driving me bonkers. After
reading the Suckerfish Dropdown article on A List Apart, I decided to try
and create a side menu based on the code I'd seen. Note that this is an
experiment and I'm only trying to get it to work in Firebird 0.7 at the
moment. Once it is working in Firebird, I'll look at adding any IE
workarounds, starting with those in the Dropdown article.

Here is the code I've got at the moment;
[snip code]
When I just had the 'main' and 'sub1' stuff, everything looked fine.

Problems began when I added the sub2 items. Although the text seems OK,
the bordered background to the UL tag seems to be getting constrained by
the border of the higher level UL.


Not sure if this is what you need, but instead of
ul {}
use:
ul, ul.sub {}

Looks better at least in my Firebird 0.7.
--
Els

Mente humana é como pára-quedas; funciona melhor aberta.

Jul 20 '05 #2
Els <el*********@tiscali.nl> wrote in
news:40**********************@dreader2.news.tiscal i.nl:
Not sure if this is what you need, but instead of
ul {}
use:
ul, ul.sub {}


That fixes it, but the better solution is to remove the width: auto from
li>ul and add an IE-only setting to provide width: auto for all ul's so the
fallback won't be a mess.

Additionally, in Opera 7.22 the sub-menus were appearing too far to the
left from their parents, requiring very rapid mouse movement to get across
the blank space before the parent disappeared. I was able to fix that by
specifying position: relative on li (thus making it the container for its
sub-menus) and specifying margin: 0 and top: and left: offsets on li>ul.
Opera doesn't seem to like absolute positioning with no offsets specified,
and apparently adds a default margin.

The final stylesheet looks like:

ul {
list-style: none; /* Remove list bullets */
background: #ddd; /* Grey background */
border: thin solid black; /* Menu border */
padding: 0; /* Remove bullet indent */
width: 7em; /* Force a thin menu */
}

li { /* Space out menu lines a bit more */
padding: 2px;
position: relative; /* Sub menus will be positioned with respect
to this */
}

li > ul {
display: none; /* Hide sub menus */
position: absolute; /* Take sub menus out of the normal flow */
left: 100%;
top: 0;
margin: 0;
}

* html ul { /* Allow proper fallback in MSIE */
width: auto
}

/* Show the sub elements for the top level item hovered over */
li:hover > ul {
display: inline; /* Display sub menu block on the same line as
top level item */
}

li:hover {
background: #aaa; /* Darken the item we are on */
cursor: default; /* Retain a pointy arrow */
}
Jul 20 '05 #3
Many thanks to both Els and Eric. Unfortunately both these approaches have
the side effect of causing the long menu items to wrap onto two lines. I
may just have to accept that, however I was surprised with the original
code when the sub1 menu got sized to fit it's contents. I was hoping that
the sub2 menu would exhibit the same behaviour.
Jul 20 '05 #4
Els


Simon Birch wrote:
Many thanks to both Els and Eric. Unfortunately both these approaches have
the side effect of causing the long menu items to wrap onto two lines. I
may just have to accept that, however I was surprised with the original
code when the sub1 menu got sized to fit it's contents. I was hoping that
the sub2 menu would exhibit the same behaviour.


Kay, just adjust the width in your code:

ul {
list-style: none; /* Remove list bullets */
background: #ddd; /* Grey background */
border: thin solid black; /* Menu border */
padding: 0; /* Remove bullet indent */
width: 7em; /* Force a thin menu */
}

ul.sub {
list-style: none; /* Remove list bullets */
background: #ddd; /* Grey background */
border: thin solid black; /* Menu border */
padding: 0; /* Remove bullet indent */
width: 10em; /* Force a thin menu */
}

This is what you want, right?

--
Els

Mente humana é como pára-quedas; funciona melhor aberta.

Jul 20 '05 #5

This thread has been closed and replies have been disabled. Please start a new discussion.

Similar topics

9
by: Preston Crawford | last post by:
I know this is probably a dumb question so please be patient with me. I've been doing HTML since 1994, but mostly for projects that had to be as completely compatible as possible and mostly...
6
by: Paul | last post by:
I use ASP and I need to know how to attaches an Iframe Id with its page so I can load menu options ( eg. 1.htm, 2.htm, 3.htm, ect...) into the Iframe from any given page on my website. The problem...
2
by: VMI | last post by:
Usually, Windows context menus have menu items that go from top to bottom: Copy Paste Cut Process .... .... Is it possible to make a Context menu so that the menu items were
3
by: Ohad Young | last post by:
Hi, I have a frameset page that contains two frames: 1. the first frame, an aspx page, contains a menu for navigating in the website. 2. the second frame contains content, pdf, html or other...
1
by: server side menu problem2 | last post by:
hi, in my site there r 2 frames: 1.menu frame 2.application display the menu is based on <A HREF=...> because I need to direct the pages to the application display frame.now I need to cuach a...
6
by: Dave | last post by:
Hello there. I'm interesting how do I create server side menu in ASP.NET, I was searching for some menus, but they are all done with DHTML or JavaScript, so I have some problems to use them. I...
6
by: Deborah | last post by:
I'm a rookie, and I guess I know just enough to be dangerous. I found a great template website, openwebsign.org, and found an open source template I really liked that even came in 2 versions. ...
0
by: Mart | last post by:
How to create side menu bar in C++ Builder? I mean something like panels on left hand side in Opera Internet Browser (after F4 pressed) or in Acrobat Reader. Now I have created project with two...
7
by: joecap5 | last post by:
I have a main window from which I want to open a separate side menu window. I then want to create a list of items on that side menu by clicking on the item names in the main window. So far I am...
0
by: ryjfgjl | last post by:
If we have dozens or hundreds of excel to import into the database, if we use the excel import function provided by database editors such as navicat, it will be extremely tedious and time-consuming...
0
by: ryjfgjl | last post by:
In our work, we often receive Excel tables with data in the same format. If we want to analyze these data, it can be difficult to analyze them because the data is spread across multiple Excel files...
0
BarryA
by: BarryA | last post by:
What are the essential steps and strategies outlined in the Data Structures and Algorithms (DSA) roadmap for aspiring data scientists? How can individuals effectively utilize this roadmap to progress...
1
by: nemocccc | last post by:
hello, everyone, I want to develop a software for my android phone for daily needs, any suggestions?
0
by: Hystou | last post by:
There are some requirements for setting up RAID: 1. The motherboard and BIOS support RAID configuration. 2. The motherboard has 2 or more available SATA protocol SSD/HDD slots (including MSATA, M.2...
0
marktang
by: marktang | last post by:
ONU (Optical Network Unit) is one of the key components for providing high-speed Internet services. Its primary function is to act as an endpoint device located at the user's premises. However,...
0
by: Hystou | last post by:
Most computers default to English, but sometimes we require a different language, especially when relocating. Forgot to request a specific language before your computer shipped? No problem! You can...
0
by: Hystou | last post by:
Overview: Windows 11 and 10 have less user interface control over operating system update behaviour than previous versions of Windows. In Windows 11 and 10, there is no way to turn off the Windows...
0
tracyyun
by: tracyyun | last post by:
Dear forum friends, With the development of smart home technology, a variety of wireless communication protocols have appeared on the market, such as Zigbee, Z-Wave, Wi-Fi, Bluetooth, etc. Each...

By using Bytes.com and it's services, you agree to our Privacy Policy and Terms of Use.

To disable or enable advertisements and analytics tracking please visit the manage ads & tracking page.