CSS垂直ul li菜单,2行垂直居中

时间:2012-05-06 07:13:33

标签: jquery html css

你好有以下奇怪的问题,如果它是一行,可以垂直居中菜单文本,但是2行会弄乱我的设计。在每个浏览器中它看起来都不同它还必须与浏览器兼容。 有人有想法吗?

这是一个在线版本:

http://jsfiddle.net/Vm57C/6/

HTML:

<ul id="vert-menu">
      <li><a href="#">Organisatie</a></li>
      <li><a href="#">Feiten en cijfers</a></li>
      <li><a href="#">Historie</a></li>
      <li><a href="#">Kennis & ontwikkeling</a></li>
      <li><a href="#">Maatschappelijk betrokken</a></li>
      <li><a href="#">Help mee</a></li>
      <li><a href="#">Samenwerking in de zorg</a></li>
      <li><a href="#" class="active">Samen leven, samen werken</a>          
        <ul class="sub-menu">
          <li><a href="#">Samen leven, samen werken</a></li>
          <li><a href="#">Catering en horeca</a></li>
          <li><a href="#">Kunst en cadeaus</a></li>
         <li><a href="#">Lenen en spelen</a></li>
         <li><a href="#">Maken en doen</a></li>
        <li><a href="#">Recreatie</a></li>
        </ul>
        </li>
      <li><a href="#">Medezeggenschap</a></li>
      <li><a href="#">Publicaties</a></li>
    </ul>

CSS:

/* verticaal menu */
#vert-menu {
margin: 0;  
padding: 0; 
}

#vert-menu ul {
margin: 0;  
padding: 0;
list-style:none;
}

#vert-menu > li {
    margin-bottom: 5px;
    color: #FFF;
    font-weight: bold;
    text-transform: uppercase;
    width: 175px;
    line-height: 30px;
    font-size: 0.9em;
    background:#FFF url(../images/vert-menu.jpg) no-repeat;
}


#vert-menu > li > a {
    padding: 0 35px 0 5px;
    display: block;
    height: 30px;
    line-height: 15px;
    vertical-align:middle;
    color: #FFF;
    text-decoration:none;
    outline:none;
}

#vert-menu > li:hover > a {
    background:#FFF url(../images/vert-menu-active.jpg) no-repeat;
    text-decoration:none;
}
#vert-menu > li > a.active {
    background:#FFF url(../images/vert-menu-active.jpg) no-repeat;
    text-decoration:none;
}

#vert-menu li > .sub-menu {
    margin:0;
    padding: 0 5px 0 5px;
}
#vert-menu li > .sub-menu > li a {
    display:block;
    line-height: 20px;
    width: 165px;
    text-transform: lowercase;
    color: #83B810;
    border-bottom-width: 1px;
    border-bottom-style: solid;
    border-bottom-color: #83B810;
    text-decoration:none; 
    outline: none;
}

#vert-menu > li > .sub-menu > li:hover > a {
    color: #750D68; 
    text-decoration:none;
}
#vert-menu > li > .sub-menu > li > a.active {
    color: #750D68; 
    text-decoration:none;
}

3 个答案:

答案 0 :(得分:2)

让它看起来像一个表格单元格:

#vert-menu > li > a {
    padding: 0 35px 0 5px;
    display: table-cell;
    height: 30px;
    line-height: 15px;
    vertical-align: middle;
    color: #FFF;
    text-decoration: none;
    outline: none;
}

答案 1 :(得分:1)

以下是此问题的解决方案:

http://www.andy-howard.com/verticalAndHorizontalAlignment/index.html

希望这对大家有所帮助

答案 2 :(得分:0)

我认为以下修改符合您的要求:

#vert-menu > li > a {
    padding: 0 35px 0 5px;
    display: block;
    height: 30px;
    line-height: 15px;
    vertical-align:middle;
    color: #FFF;
    text-decoration:none;
    text-align: center;
}

我添加了text-align:center

但我个人更喜欢左对齐版本。