css - 如何使垂直下拉菜单居中

标签 css menu dropdown

我正在开发一个新的 wordpress 网站,遇到了下拉菜单的 CSS 问题。目前它们与主菜单或父菜单项左对齐。我的偏好是它们以主菜单或父菜单项为中心。

这是开发中网站的链接:http://centraltexasdistrict.com/welcome/

这是一张图片的链接,它给出了我正在寻找或试图实现的目标的想法:http://centraltexasdistrict.com/wp-content/uploads/CTD-menu.jpg

这是我正在使用的当前 CSS:

    .menu-main-container {
    margin-left: auto;
    margin-right: auto;
    width: 690px;
    padding: 0 0 0 20px;
    height: 35px;
    z-index: 10;
    line-height: 35px;
    }

    .menu-main-menu-container ul li ul{ text-align:center; }

    .main-navigation {
    clear: both;
    margin: 0 auto;
    max-width: 1080px;
    min-height: 36px;
    position: relative;
    }

    #navbar {
    display: block;
    height: 36px;
    width: 100%;
    margin-top: -27px;
    z-index: 10;
    position: absolute;
    }

    #site-navigation {
    padding: 0px;
    height: 30px;
    z-index: 10;
    line-height: 30px;
    float: left;        
    }

    ul.nav-menu,
    div.nav-menu > ul {
    margin: 0;
    padding: 0px;
    }

    .nav-menu li {
    display: inline-block;
    position: relative;
    }

    .nav-menu li a {
    display: block;
    font-family: 'Lato', sans-serif;
    line-height: 30px;
    color: #aaaaaa;
    font-weight: 400;
    text-align: center;
    text-transform:uppercase;
    text-decoration: none;
    letter-spacing: 1px;
    float: left;
    font-size: 12px;
    padding: 30px 7px 0px 7px;
    margin-bottom: 5px;
    }

    .nav-menu li:hover > a,
    .nav-menu li a:hover,
    .nav-menu li:focus > a,
    .nav-menu li a:focus {
    color: #ffffff;
    background-color: #353535;
    }

    .nav-menu .sub-menu,
    .nav-menu .children {
    background-color: #e07726;
    padding: 0px;
    position: absolute;
    z-index: 99999;
    overflow: hidden;
    clip: rect(1px, 1px, 1px, 1px);
    margin-top: 65px;
    }

    .nav-menu .sub-menu ul,
    .nav-menu .children ul {
    border-left: 0;
    left: 100%;
    top: 0;
    }

    .sub-menu {
    text-align: center;
    width: 100%;
    left: auto; 
    }       

    .sub-menu li {
    display: inline-block;
    width: auto;
    padding: 0px;
    }

    .sub-menu li a {
    display: block;
    height: 24px;
    font-family: 'Lato', sans-serif;
    line-height: 24px;
    font-weight: 400;
    text-align: left;
    text-decoration: none;
    text-transform: none;
    letter-spacing: 1px;
    float: left;
    font-size: 11px;
    padding: 2px 10px 2px 10px;
    color: #ffffff;
    white-space: nowrap;
    }

    .sub-menu li:hover > a,
    .sub-menu li a:hover,
    .sub-menu li:focus > a,
    .sub-menu li a:focus {
    background-image: none;
    color: #ac5411;
    background-color: transparent;
    }

    ul.nav-menu ul a,
    .nav-menu ul ul a {
    color: #fff;
    margin: 0;
    }

    ul.nav-menu li:hover > ul,
    .nav-menu ul li:hover > ul,
    ul.nav-menu .focus > ul,
    .nav-menu .focus > ul {
    clip: inherit;
    overflow: inherit;
    height: inherit;
    width: inherit;
    }

    .nav-menu .current_page_item > a,
    .nav-menu .current_page_ancestor > a,
    .nav-menu .current-menu-item > a,
    .nav-menu .current-menu-ancestor > a {
    color: /* #333333 */;
    }

最佳答案

一个快速的解决方案是给子菜单一个指定的宽度:

ul.nav-menu li:hover > ul, .nav-menu ul li:hover > ul, ul.nav-menu .focus > ul, .nav-menu .focus > ul {
  clip: inherit;
  overflow: inherit;
  height: inherit;
  width: 200px; /* width for the submenu */
  left: 50%; /* position it 50% to the left */
  margin-left: -100px; /* negative margin half of with to center it */
}

或者,如果您不想指定宽度,请使用翻译(不适用于所有旧浏览器,您可能需要一些前缀):

ul.nav-menu li:hover > ul, .nav-menu ul li:hover > ul, ul.nav-menu .focus > ul, .nav-menu .focus > ul {
  clip: inherit;
  overflow: inherit;
  height: inherit;
  transform: translate(-50%, 0);
  left: 50%;
}

关于css - 如何使垂直下拉菜单居中,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38690613/

相关文章:

jquery - 为表格中的动态文本框设置类验证

javascript - 随着容器宽度的增加,是否可以均匀分布图像,同时增加或减少每行中的元素数量?

javascript - 上下文菜单的 jquery 停止事件

javascript - 带有原型(prototype)的简单水平 Javascript 导航

CSS 下拉列表在 IE 或 Edge 中不起作用

php - 不能在 php 文件中使用变量而不是 css

html - 选择子菜单项时遇到问题

css - 悬停时没有列表其余部分的单个 li 顶部边框

css - 在 Bootstrap 4 中单击 DropdownItem 列表时如何更改 DropdownToggle 背景颜色

html - 我可以在 PrimeNG 下拉列表的突出显示项中包含一个图标吗?