Solved

CSS Center Text in a li tag

Posted on 2010-08-25
15
465 Views
Last Modified: 2013-11-19
I have a Navigation bar created in CSS. I would like to verically center the text with in the <li> tag.
The catch is that some of the nav text will have 2 lines. See attachment.

So i would like to get the 1 liners vertically centered. Is this possible?

I have attached sample code
-------CSS--------

#mainNav {
            font-size:11px;
            height:45px;
            margin: 0px;
            padding: 0px;
      }
              
#mainNav li {
            display:block;
            float: left;
            margin-top: 7px;
      }

#mainNav li a {
            text-decoration:none;
            color: #000;
        text-align:center;
        height:28px;
		width:96px;
            padding:0px 0px 5px 0px;
        display:block;
            background-image: url(/images/15/lightEffects_but_sprite.jpg);
            background-repeat: repeat-x;
            background-position:legt top;
      }
ul#mainNav {
	list-style-type: none;
}

#mainNav li a:hover {
            color:#000;
        display:block;
            background-image: url(/images/15/lightEffects_but_sprite.jpg);
            background-repeat: repeat-x;
            background-position: left bottom;
      }


------HTML ------------
<ul id="mainNav">
                                <!-- CSS Tabs -->
        <li><a  href='/listings/OpenHouses.aspx'>Office Open Houses</a></li><li><a  href='/listings/Sold.aspx'>Our Sold Properties</a></li><li><a  href='/listings/Default.aspx'>My Office Listings</a></li><li><a  href='/news/Guides.aspx'>Buyer & Seller Info</a></li><li><a  href='/Demographics.aspx'>Neighborhoods/
Schools</a></li><li><a  href='/Cma.aspx'>Market Analysis Lead </a></li><li><a  href='/Calcs.aspx'>Financial Calculators</a></li><li><a  href='/Videos.aspx'>Consumer Video Tips</a></li><li><a  href='/Contact.aspx'>Contact Us</a></li><li><a href='/Custom1.aspx'>Links</a></li>

    </ul>

Open in new window

nav-bar.jpg
0
Comment
Question by:MLSLI
[X]
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
15 Comments
 
LVL 13

Expert Comment

by:myderrick
ID: 33527084
Try using line-height for the <li> height elements. This will make the contents of the <li> stay in the middle.

Good luck.

MD
0
 
LVL 13

Expert Comment

by:myderrick
ID: 33527094
One more thing is you have to make sure the height is enough to accomodate the double line for the items with two lines.

MD
0
 
LVL 40

Expert Comment

by:gurvinder372
ID: 33528514
another method is to update <<#mainNav li a>>  to update the padding to

#mainNav li a
{    
        text-decoration:none;
        color: #000;
        text-align:center;
        height:28px;
      width:96px;
        display:block;
        background-image: url(/images/15/lightEffects_but_sprite.jpg);
        background-repeat: repeat-x;
        background-position:legt top;

        padding: 5px 0px;
}

also try vertical align
http://www.w3schools.com/css/pr_pos_vertical-align.asp

However, i think line height answer given by fellow expert above is the best answer

more solutions here
http://blog.themeforest.net/tutorials/vertical-centering-with-css/
0
Industry Leaders: We Want Your Opinion!

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
LVL 5

Expert Comment

by:roxviper
ID: 33529251
Hi,

Personally I use padding for vertical align the text in menus. For example if you have a height of 25px on the menu, I put a padding-top of 10px; on the <a> tag and I make the height 15px.

See if it helps you
 
0
 
LVL 4

Expert Comment

by:acashok
ID: 33529804
try with this:

#mainNav li {
            display:block;
            float: left;
            line-height:45px;
      }

hope this help
0
 
LVL 13

Expert Comment

by:myderrick
ID: 33530708
Exactly what I suggested.  The padding option will do but you have to deal with IE and its issues with paddings and margin.

Let us wait for the author to respond and we'll advise later.

MD
0
 

Author Comment

by:MLSLI
ID: 33532624
Thanks for all who responded.

myderrick: Line-height doesn't work because it makes the 2 lines spread out. see image attached

gurvinder372: Padding or Margin doesn't work because it moves all the text down without vertically centering the one liners.Also Vertical-align: doesn't work on a
  • tag. I tried changing the display:table; or display:table-cell; doesn't see to take.

    Thanks for the effort
  • 0
     
    LVL 13

    Expert Comment

    by:myderrick
    ID: 33532702
    Line-hieght makes the 2 lines spread out? That shouldn't be happening as the line-height property works on the height and not width.

     You must specify the height to accommodate the 2 lines and remove any extra paddings that you do not require.

    Good luck

    MD


    0
     

    Author Comment

    by:MLSLI
    ID: 33533182
    Sorry myderrick must be a small miss communication here.

    Its not spreading out in width it's... spreading in height ** See attached image * *******
    I really don't need the 2 lines centered in the
  • i need the 1 liner vertically center within the
  • . So i am assuming that i need to use a % or auto. Can it be done?
  • line-height.jpg
    0
     
    LVL 13

    Expert Comment

    by:myderrick
    ID: 33533569
    Now that complicates the problem. You can use tables for just the menus. That solves all the problems

    Or

    You could figure out which of these will help. Either way, it is complicated.

    I will try and work something out but before then, Good Luck

    MD
    0
     

    Author Comment

    by:MLSLI
    ID: 33533609
    MD,

    Have you ever used the Display: property table or table-cell on <li> tags?

    I tried but have had no luck doing so
    0
     
    LVL 13

    Expert Comment

    by:myderrick
    ID: 33534324
    No. I haven't.

    For the one line to center, you need to use line-height and specify a width for the entire #mainNav as well as the <li>. The only problem I have now is the 2 line items. Once you use line-height they will spread out downward.

    Have you consodered using a table for the menu?

    OR

    Any of these ideas:
    http://blog.themeforest.net/tutorials/vertical-centering-with-css/

    MD
    0
     

    Accepted Solution

    by:
    MLSLI earned 0 total points
    ID: 33648215
    O.K after a lot of research and talking to a hi level professional this is what i came up with.

    #mainNav li a
    {    
            text-decoration:none;
            color: #000;
            text-align:center;
            height:28px;
          width:96px;
           
    display:table-cell;  < -- works in FF,chome, safari -->
    vertical-align:middle: <-- i first used center, not a property of vertical-align -->
         
      background-image: url(/images/15/lightEffects_but_sprite.jpg);
            background-repeat: repeat-x;
            background-position:legt top;

            padding: 5px 0px;
    }

    This needs hacks for IE7 and IE8. Changing display to block
    0
     
    LVL 58

    Expert Comment

    by:Gary
    ID: 39457814
    This question has been classified as abandoned and is closed as part of the Cleanup Program. See the recommendation for more details.
    0

    Featured Post

    [Webinar] Code, Load, and Grow

    Managing multiple websites, servers, applications, and security on a daily basis? Join us for a webinar on May 25th to learn how to simplify administration and management of virtual hosts for IT admins, create a secure environment, and deploy code more effectively and frequently.

    Question has a verified solution.

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

    Suggested Solutions

    Title # Comments Views Activity
    CSS DIV Height in Percent 1 39
    CSS in HTML 5 68
    setting backkground on single page on wordpress 4 41
    CSS - Centering an image 2 48
    Introduction Knockoutjs (Knockout) is a JavaScript framework (Model View ViewModel or MVVM framework).   The main ideology behind Knockout is to control from JavaScript how a page looks whilst creating an engaging user experience in the least …
    Styling your websites can become very complex. Here I'll show how SASS can help you better organize, maintain and reuse your CSS code.
    In this tutorial viewers will learn how to style different bullet points for unordered lists in CSS. Begin with a normal unordered list; the default bullet point is a solid circle: In the CSS, create a defined class of unordered list by typing "ul.S…
    The viewer will receive an overview of the basics of CSS showing inline styles. In the head tags set up your style tags: (CODE) Reference the nav tag and set your properties.: (CODE) Set the reference for the UL element and styles for it to ensu…

    752 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