Solved

CSS priority

Posted on 2009-05-06
3
322 Views
Last Modified: 2012-05-06
All,

I'm having a problem getting a css menu to format properly.  There's one large menu item that's pushing all of the other menu items out of alignment.  If I expand the width of all menu items, the menu becomes too large for the page.  If I try to override just that one menu items' width, with the "style" tag, css expands the width of the menu item but flows the text at the original setting.  Any suggestions?

The code is below, and thanks!
CSS:

#menu ul

{

	list-style: none;

	padding: 0;

	margin: 0;

} 
 

#menu li

{

	float:left;

	margin: 0 0 0.15em;

	font-size:10pt;

	font-weight:bold;

	font-family:arial, helvetica, san-serif;

	
 

} 
 

#menu li a

{

	background: #e85f31;

	height: 2em;

	line-height: 2em;

	float: left;

	width: 10em;

	display: block;

	color: #ffffff;

	text-decoration: none;

	text-align: center;

} 
 

HTML:

<div id="menu">

<ul>

<li><a href="#">Short</a></li>

<li style="width:15em;"><a href="#">Long, long, long, long menu item</a></li>

<li><a href="#">Short</a></li>

<li><a href="#">Short</a></li>

<li><a href="#">Short</a></li>

</ul>

</div><!-- end menu -->

Open in new window

0
Comment
Question by:Raydot
3 Comments
 
LVL 13

Accepted Solution

by:
Brian Withun earned 250 total points
ID: 24318562
I think padding is the trick here:

#menu li a
{
      background: #e85f31;
      height: 2em;
      line-height: 2em;
      float: left;
      /*width: 6em;*/
      display: block;
    padding: 0 1em;
      color: #ffffff;
      text-decoration: none;
      text-align: center;
}
<html>

<head>

<style>
 

#menu ul

{

	list-style: none;

	padding: 0;

	margin: 0;

} 

 

#menu li

{

	float:left;

	margin: 0 0 0.15em;

	font-size:10pt;

	font-weight:bold;

	font-family:arial, helvetica, san-serif;

	border-left: 1px solid white;

    border-right: 1px solid white;

 

} 

 

#menu li a

{

	background: #e85f31;

	height: 2em;

	line-height: 2em;

	float: left;

	/*width: 6em;*/

	display: block;

    padding: 0 1em;

	color: #ffffff;

	text-decoration: none;

	text-align: center;

} 

 

.longlong

{

    text-decoration:underline;

}
 

</style>

</head>

<body>
 

<div id="menu">

<ul>

<li><a href="#">Short</a></li>

<li><a href="#">Long, long, long, long menu item</a></li>

<li><a href="#">Short</a></li>

<li><a href="#">Short</a></li>

<li><a href="#">Short</a></li>

</ul>

</div><!-- end menu -->
 

</body>

</html>

Open in new window

longlong.jpg
0
 
LVL 7

Expert Comment

by:ycTIN
ID: 24323230
inline-style have are highest priority


        <li>
            <a href="#" style="width:auto;">Long, long, long, long menu item</a>
        </li>
0
 
LVL 3

Author Closing Comment

by:Raydot
ID: 31578644
Thanks!  Why doesn't it need to have a width?
0

Featured Post

Is Your Active Directory as Secure as You Think?

More than 75% of all records are compromised because of the loss or theft of a privileged credential. Experts have been exploring Active Directory infrastructure to identify key threats and establish best practices for keeping data safe. Attend this month’s webinar to learn more.

Question has a verified solution.

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

Suggested Solutions

Title # Comments Views Activity
Fixed div within Bootstrap carousel item 11 54
Gradient CSS 4 30
Error on link 14 38
two div layout one vertical other horizontal. 5 8
When writing CSS, there are a few simple rules that will make your life easier.    1. Using ‘* {box-sizing:border-box;}’. Using this will wrap all your elements in a nice little compact box-model that will give you the width you want, like so... …
This article demonstrates how to create a simple responsive confirmation dialog with Ok and Cancel buttons using HTML, CSS, jQuery and Promises
In this tutorial viewers will learn how to position items using CSS's three positioning types Create a new HTML document with an internal stylesheet.: Create another div in CSS and name it Absolute : Type "position:absolute;" and "top:10px; left:50p…
Learn how to create flexible layouts using relative units in CSS.  New relative units added in CSS3 include vw(viewports width), vh(viewports height), vmin(minimum of viewports height and width), and vmax (maximum of viewports height and width).

920 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

Need Help in Real-Time?

Connect with top rated Experts

16 Experts available now in Live!

Get 1:1 Help Now