我正在尝试构建一个嵌套列表,当单击顶级“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;}
。
关于javascript - 单击时格式化隐藏的嵌套列表时出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/26819500/