1

こんにちは、次のような奇妙な問題があります。メニュー テキストが 1 行の場合は垂直方向に中央揃えにすることができますが、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;
}
4

3 に答える 3

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;
}
于 2012-05-06T08:46:02.223 に答える
1

この問題の解決策は次のとおりです。

http://www.andy-howard.com/verticalAndHorizo​​ntalAlignment/index.html

これが皆さんのお役に立てば幸いです

于 2012-05-13T06:43:45.097 に答える
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た。

しかし、個人的には左揃えのバージョンが好きです。

于 2012-05-06T07:34:24.890 に答える