Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people, just like you, are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
Solved

CSS Horizontal separator line in drop-down/up menu

Posted on 2006-06-28
4
2,455 Views
Last Modified: 2008-02-01
Hi Experts.  I need to create red dividing / separating line between <li> items in my menu.  If you view http://www.ideascapes.net/temp/final2.html in Firefox, hover over any menu item and the drop-up list looks exactly as I want it to, without the red line.  It definitely doesn't look right when viewed in IE.  I can't seem to get heights/line-heights correct for the IE stylesheet, much less figure out what happens when I add a separating line (regardless of browser).  Menu item "Practices" has an example of what I'm trying to achieve, just not totally correct.  Line should be red, 1px, cover 50% of available area (roughly 44px) and appear above and below each <li>.  Help would be greatly appreciated.  Apologies in advance for the ugly CSS.
0
Comment
Question by:Maudelle
  • 2
  • 2
4 Comments
 

Author Comment

by:Maudelle
ID: 17010192
Ok, I managed to get Firefox looking exactly the way I want, except for the red line at the top of each fly-up where it's on a red background.  If it goes up far enough to reach the white background, it's perfect.

I'm still having problems with IE.  Source if available at http://www.ideascapes.net/temp/final.html

Code samples below:

(separator line, read by all browsers)
#divider {
position:relative;
left:22px;
width:44px;
border-bottom: 1px solid red;
height: 1px;
font-size: 1px;
line-height: 1px;
}

CSS Rules for IE browsers:

.menu ul li a:hover {
color:red;
font-weight:bold;
background:#fff;
font-size:10pt;
}

.menu ul li a:hover ul {
display:block;
position:absolute;
bottom:36px;
left:0;
font-family:Arial, Helvetica, sans-serif;
border-right:2px solid white;
line-height:2px;
}

.menu ul li a:hover ul li {
display:block;
background:#fff;
color:#000;
width:89px;
clear: both;
left: 0px;
height:17px;
margin:0px;
padding:0px;
}

.menu ul li a:hover ul li a {
display:block;
background:#fff;
color:black;
width:101%;
font-size:10px;
line-height:2px;
font-weight:normal;
}

.menu ul li a:hover ul li a:hover {
background:#fff;
color:red;
font-weight:bold;
font-size:10px;
}

CSS Rules for non-IE browsers:

.menu ul li:hover a {
color:red;
font-weight:bold;
font-size:10pt;
background:#fff;
}

.menu ul li:hover ul {
display:block;
position:absolute;
bottom:38px;
left:0;
font-family:Arial, Helvetica, sans-serif;
font-weight:normal;
line-height:2px;
}

.menu ul li:hover ul li a.hide {
background:#fff;
color:#000;
}

.menu ul li:hover ul li {
display:block;
background:#fff;
color:#000;
width:89px;
height:17px;
clear:both;
left:0px;
margin:0px;
padding:0px;
}

.menu ul li:hover ul li ul {
display: none;
}

.menu ul li:hover ul li a {
display:block;
background:#fff;
color:#000;
width:101%;
font-size:11px;
font-weight:normal;
line-height:2px;
z-index:20;
}

.menu ul li:hover ul li a:hover {
background: #fff;
color: red;
font-weight:bold;
font-size:11px;
white-space:nowrap;
overflow:visible;
}
0
 
LVL 2

Expert Comment

by:sandylaw
ID: 17019101
Getting 404 page when trying to view your example.
0
 

Author Comment

by:Maudelle
ID: 17043786
Sorry, I had given up on getting an answer here.  Link is now at http://www.ideascapes.net/fiderion/preview/default.html.  I managed to get it to work by using 3 div's to create the lines (1 white border line left, 1 red border line in the center, 1 white border line right).  This of course makes the code not validate because the id is used more than once on the page.  Would greatly appreciate it if you could help with a class for use on these elements
0
 
LVL 2

Accepted Solution

by:
sandylaw earned 500 total points
ID: 17045749
I took what you had and did the following - this isn't complete, but just a suggestion:

(in the html - i've removed all extra divs and styles, replacing it with a horizontal line):

        <UL>
          <LI><A
          href="http://www.ideascapes.net/fiderion/preview/default.html">Placements</A>
              <hr class="redline" />
          </LI>
          <LI><A
          href="http://www.ideascapes.net/fiderion/preview/default.html">Testimonials</A>
              <hr class="redline" />
          </LI>
          <LI><A
          href="http://www.ideascapes.net/fiderion/preview/default.html">Clients</A>
              <hr class="redline" />
          </LI>
        </UL>

in the css:

hr.redline {
      PADDING: 0px;
      MARGIN: 0px;
      color: #e31836;
      background-color: #e31836;
      width: 45px;
      height: 1px;
}


I know it the spacing is not exactly right yet, I didn't have much time to work with it, but you can play with the extra whitespace/padding around the <hr/> and the other tags surrounding.  I've only used the IE css, didn't have a chance to work the other css.

Hope it's something in the right direction.

Oh...one other thing.  I took a look at your code - why didn't you just change all your ids to classes?  The ones you have existing (that you have in your div tags)?  Probably less work for you and would validate.
0

Featured Post

Announcing the Most Valuable Experts of 2016

MVEs are more concerned with the satisfaction of those they help than with the considerable points they can earn. They are the types of people you feel privileged to call colleagues. Join us in honoring this amazing group of Experts.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

This is a how to build your own CSS3 slideshow and when I say CSS3 I mean just CSS with no javascript in sight! There a few examples online of how to do this but most just show you an example without any explanation, others make it more complicat…
Today, the web development industry is booming, and many people consider it to be their vocation. The question you may be asking yourself is – how do I become a web developer?
In this Micro Tutorial users will learn how to embed custom fonts into websites using @font-face in CSS Select a font: Ensure the EULA allows you to use @font-face: Download the font: Get the browser-compatible files you need: Edit your CSS       - Name …
In this Micro Tutorial viewers will learn how to create a CSS image sprite (In a later tutorial, viewers will learn how to use CSS and HTML to create a navigation menu using this sprite) Open a new Photoshop document with a width of (Icon width)x(N…

790 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question