0

在我的导航菜单中,我将li高度设置为 100%,以便文本在菜单中垂直居中。这在 Chrome、Firefox、Safari 等上运行良好,但在 IE 中它不会拉这个 CSS。li仅与文本本身一样高,因此菜单元素与顶部对齐。

.nav li{height:100%}

我对此进行了调查,有人建议所有父容器也必须具有 100% 的高度才能在 IE 中工作,但它们确实如此。

有人有想法么?

提前致谢!

这是代码:

<nav role="navigation">
          <ul class="nav">
            {% for link in linklists.main-menu.links %}
            {% assign has_sub_menu = false %}
            {% assign has_sub_categories = false %}
            {% assign parent_link_active = false %}
            {% assign child_list_handle = link.title | handle %}
            {% if linklists[child_list_handle] and linklists[child_list_handle].links.size > 0 %}
              {% assign has_sub_menu = true %}
              {% for l in linklists[child_list_handle].links %}
                {% if page_title == l.title %}
                  {% assign parent_link_active = true %}
                {% endif %}
              {% endfor %}
            {% elsif link.type == 'collection_link' and link.object.all_tags.size > 0 %}
              {% assign has_sub_categories = true %}
            {% endif %}
            <li class="nav-item{% if forloop.first %} first{% elsif forloop.last %} last{% endif %}{% if link.active or parent_link_active %} active{% endif %}{% if has_sub_menu or has_sub_categories %} has-dropdown{% endif %}">
              {{ link.title | link_to: link.url }}
              {% if has_sub_menu or has_sub_categories %}
              <ul class="sub-nav">
                <li class="sub-nav-niblet"></li>
                {% if has_sub_menu %}
                  {% for l in linklists[child_list_handle].links %}
                  <li class="sub-nav-item{% if forloop.first %} first{% elsif forloop.last %} last{% endif %}{% if l.active %} active{% endif %}">
                    <a class="{% if forloop.first %}first{% elsif forloop.last %}last{% endif %}" href="{{ l.url }}">{{ l.title }}</a>
                  </li>
                  {% endfor %}
                {% elsif has_sub_categories %}
                  {% for tag in link.object.all_tags %}
                  <li class="sub-nav-item{% if forloop.first %} first{% elsif forloop.last %} last{% endif %}{% if current_tags contains tag %} active{% endif %}">
                    <a class="{% if forloop.first %}first{% elsif forloop.last %}last{% endif %}" href="{{ link.url }}/{{ tag | handle }}">{{ tag }}</a>
                  </li>
                  {% endfor %}
                {% endif %}
              </ul>
              {% endif %}
            </li>
            {% endfor %}
          </ul>
        </nav>

和CSS:

nav {
    display: block;
    height: 100%;
    position: absolute;
    width: auto;
    right: 0;
    float: none;
    margin-right: 210px;
}

.nav {
    display: table;
    float: right;
    height: 100%;
    margin: 0;
}

    .nav li { 
        display: table;
        float: left;
        height: 100%;
        position: relative;
        width: auto;
    }

        .nav li a {
            color: #eee;
            display: table-cell;
            font-size: 18px;
            height: 100%;
            padding: 0 30px;
            vertical-align: middle;
        }

            .nav li a:hover {
                color: #fff;
                background-color:#1d1a1c;
            }
4

1 回答 1

1

嗨,请在你的代码上试试这个。在你的 CSS 中改变你的属性.navfromdisplay:table到 this

.nav {
   display: block;
}
于 2013-10-22T15:25:35.197 回答