点击时设置隐藏嵌套列表格式有问题

Trouble with formatting hidden nested list on click

本文关键字:列表 格式 有问题 嵌套 隐藏 设置      更新时间:2023-09-26

我正在尝试构建一个嵌套列表,当单击顶层"li"时,它会下拉并显示嵌套列表。我在网上找到了一些例子来说明如何做到这一点(http://jsfiddle.net/theuideveloper/DFHWd/4/)在大多数情况下,我可以让js的主要功能发挥作用。

我的问题是,当我点击第一个"li"时,我的顶级列表项目被分为4列。它将我的嵌套列表直接放在这个"li"下,将它下面的第二行向右推,并且没有跨越4列,嵌套列表在这个位置上都是混乱的。

下面是一张图片,试图更好地解释:

项目1项目2项目3项目4

-子项1-子项2-子项3-子项4

项目5项目6项目7项目8

因此,当我单击项目1时,我希望嵌套的子项目像上面一样显示。目前是这样的:

项目1项目2项目3项目4

-子项1
-子项2
-子项3

这是代码:

<ul class="promos">
<li class="expanded"><a href="#"><img src="{{skin url="images/category-button.png"}}" alt="" /></a>
  <ul class="sub-cat">
    <li.sub-cat"><a href="foo">Sub Item 1</a></li>
    <li.sub-cat"><a href="foo">Sub Item 2</a></li>
    <li.sub-cat"><a href="foo">Sub Item 3</a></li>
    <li.sub-cat"><a href="foo">Sub Item 4</a></li>
  </ul>
</li>
<li class="expanded"><img src="{{skin url="images/category-button.png"}}" alt="" /></li>
<li class="expanded"><img src="{{skin url="images/category-button.png"}}" alt="" /></li>
<li class="expanded"><img src="{{skin url="images/category-button.png"}}" alt="" /></li>
<li class="expanded"><img src="{{skin url="images/category-button.png"}}" alt="" /></li>
<li class="expanded"><img src="{{skin url="images/category-button.png"}}" alt="" /></li>
</ul>

和css

.promos {
  margin: 0 0 10px 0;
  padding: 0;
  width: 100%;
}
.promos:after {
  content: '';
  display: table;
  clear: both;
}
/* Specifying the body only in order to override the .std ul li styling */
body .promos > li {
  margin: 0 0 10px 0;
  list-style: none;
  text-align: center;
  position: relative;
  border: 1px solid #cccccc;
  -moz-user-select: none;
  -ms-user-select: none;
  -webkit-user-select: none;
  -o-user-select: none;
  user-select: none;
}
.promos > li:last-child {
  margin-bottom: 0;
}
.promos img {
  max-width: 100%;
  width: 100%;
}
.promos a:hover {
  filter: progid:DXImageTransform.Microsoft.Alpha(Opacity=80);
  opacity: 0.8;
  display: block;
}
.promos span {
  color: #FFFFFF;
  text-transform: uppercase;
  position: absolute;
  display: block;
  width: 100%;
  top: 10%;
  font-weight: 500;
  font-size: 20px;
  font-family: "Raleway", "Helvetica Neue", Verdana, Arial, sans-serif;
  text-shadow: 1px 1px 3px #555555;
}
.promos strong {
  font-weight: 600;
  font-size: 26px;
  display: block;
}
@media only screen and (min-width: 771px) {
  .promos span {
    font-size: 16px;
  }
  .promos strong {
    font-size: 17px;
  }
  /* Config: Three columns + flexible gutter */
  body .promos > li {
    float: left;
    width: 23.2142875%;
    margin-right: 2.38095%; /* 30 / 1260 (margin divided by total width) */
  }
  .promos > li:nth-child(4n ) {
    margin-right: 0;
  }
}
@media only screen and (min-width: 880px) {
  .promos span {
    font-size: 18px;
  }
  .promos strong {
    font-size: 24px;
  }
}

CSS定义的.sub-cat与.promos完全相同,但需要使用不同的类名来隐藏它直到点击,但我需要对文本大小、颜色等使用相同的属性。

谢谢!

我想这只是以下打字错误的原因:

<ul class="sub-cat">
   <li.sub-cat"><a href="foo">Sub Item 1</a></li>
   ...

而不是例如

<ul class="sub-cat">
    <li><a href="foo">Sub Item 1</a></li>
     ...

(除非这是一种我不知道的符号)。然后就可以像Marcelo在评论中建议的那样添加.sub-cat li {display:inline-block;}了。

Fiddle