具有全角边框和缩进的嵌套列表

Wil*_*art 5 css border html-lists

我正在努力实现以下结果:

样式嵌套列表

到目前为止,我已经写了以下内容:

a {
    text-decoration: none;
}
ul {
    margin: 0;
    padding: 0;
    list-style-type: none;
}
li {
    border-top: 1px solid;
    border-bottom: 1px solid;
    padding-left: 1em;
    line-height: 2em;
}
li li {
    margin-left: -1em;
    padding-left: 2em;
    border-bottom: none;
}
li li li {
    margin-left: -2em;
    padding-left: 3em;
    border-bottom: none;
}
Run Code Online (Sandbox Code Playgroud)

演示:https : //jsfiddle.net/9h891a0s/1/

但是,我正在寻找一种可以实现无限深度的解决方案。有没有干净的解决方案?

Sti*_*ers 5

position:absolute通过使用边框技巧来看看这一点。

body {
    margin: 0;
    padding: 1em;
}
body > ul {
    border-bottom: 1px solid black;
    overflow: hidden;
}
a {
    text-decoration: none;
}
ul {
    margin: 0;
    padding: 0;
    list-style-type: none;
}
li {
    line-height: 2em;
    position: relative;
}
li ul {
    padding-left: 1em;
}
li:after {
    content:"\00A0";
    position: absolute;
    width: 200%;
    left: -100%;
    top: 0;
    border-top: 1px solid black;
    z-index: -1;
}
Run Code Online (Sandbox Code Playgroud)
<ul>
    <li><a href="#">Level 1</a>
        <ul>
            <li><a href="#">Level 2</a></li>
            <li>
                <a href="#">Level 2</a>
                <ul>
                    <li><a href="#">Level 3</a></li>
                    <li><a href="#">Level 3</a></li>
                    <li><a href="#">Level 3</a></li>
                </ul>
            </li>
            <li><a href="#">Level 2</a></li>
        </ul>
    </li>
</ul>
Run Code Online (Sandbox Code Playgroud)

小提琴演示: http://jsfiddle.net/Lr5cmoo6/


Alb*_*dzM 1

无法通过嵌套来增加元素的边距/填充。

希望这可以帮助您:

a {
    text-decoration: none;
}
ul {
    margin: 0;
    padding: 0;
    list-style-type: none;
}
li {
    border-top: 1px solid;
    border-bottom: 1px solid;
    line-height: 2em;
}
li li {
    border-bottom: none;
}
li li a {
    margin-left: 1em;
}
li li li a {
    margin-left: 2em;
}
li li li li a {
    margin-left: 3em;
}
Run Code Online (Sandbox Code Playgroud)