Lien d’origine: https://codepen.io/ross-angus/pen/jwxMjL
HTML:
<section class="treeView"> <figure> <figcaption>Example DOM structure diagram</figcaption> <ul class="tree"> <li><code>html</code> <ul> <li><code>head</code> <ul> <li><code>title</code></li> </ul> </li> <li><code>body</code> <ul> <li><code>header</code> <ul> <li><code>h1</code></li> <li><code>p</code></li> </ul> </li> <li><code>nav</code> <ul> <li><code>a</code></li> <li><code>a</code></li> <li><code>a</code></li> <li><code>a</code></li> </ul> </li> <li><code>main</code> <ul> <li><code>h1</code></li> <li><code>article</code> <ul> <li><code>h2</code></li> <li><code>p</code></li> <li><code>p</code></li> </ul> </li> </ul> </li> <li><code>aside</code> <ul> <li><code>h2</code></li> <li><code>p</code></li> <li><code>p</code> <ul> <li><code>a</code></li> </ul> </li> </ul> </li> <li><code>footer</code> <ul> <li><code>nav</code> <ul> <li><code>a</code></li> <li><code>a</code></li> <li><code>a</code></li> <li><code>a</code></li> </ul> </li> </ul> </li> </ul> </li> </ul> </li> </ul> </figure> <figure> <figcaption>Example sitemap</figcaption> <ul class="tree"> <li><span>Home</span> <ul> <li><span>About us</span> <ul> <li><span>Our history</span> <ul> <li><span>Founder</span></li> </ul> </li> <li><span>Our board</span> <ul> <li><span>Brad Whiteman</span></li> <li><span>Cynthia Tolken</span></li> <li><span>Bobby Founderson</span></li> </ul> </li> </ul> </li> <li><span>Our products</span> <ul> <li><span>The Widget 2000™</span> <ul> <li><span>Order form</span></li> </ul> </li> <li><span>The McGuffin V2</span> <ul> <li><span>Order form</span></li> </ul> </li> </ul> </li> <li><span>Contact us</span> <ul> <li><span>Social media</span> <ul> <li><span>Facebook</span></li> </ul> </li> </ul> </li> </ul> </li> </ul> </figure> </section>
CSS:
.treeView .tree, .treeView .tree ul, .treeView .tree li { list-style: none; margin: 0; padding: 0; position: relative; } .treeView .tree { margin: 0 0 1em; text-align: center; } .treeView .tree, .treeView .tree ul { display: table; } .treeView .tree ul { width: 100%; } .treeView .tree li { display: table-cell; padding: .5em 0; vertical-align: top; } .treeView .tree li:before { outline: solid 1px #666; content: ""; left: 0; position: absolute; right: 0; top: 0; } .treeView .tree li:first-child:before {left: 50%;} .treeView .tree li:last-child:before {right: 50%;} .treeView .tree code, .treeView .tree span { border: solid .1em #666; border-radius: .2em; display: inline-block; margin: 0 .2em .5em; padding: .2em .5em; position: relative; } .treeView .tree code { font-family: monaco, Consolas, 'Lucida Console', monospace; color:black; } .treeView .tree ul:before, .treeView .tree code:before, .treeView .tree span:before { outline: solid 1px #666; content: ""; height: .5em; left: 50%; position: absolute; } .treeView .tree ul:before { top: -.5em; } .treeView .tree code:before, .treeView .tree span:before { top: -.55em; } .treeView .tree > .treeView li {margin-top: 0;} .treeView .tree > .treeView li:before, .treeView .tree > .treeView li:after, .treeView .tree > .treeView li > code:before, .treeView .tree > .treeView li > .treeView span:before { outline: none; }