如何在树结构可视化中使用CSS连接子项 [英] How to connect a child item in a tree-structure visualization with CSS

查看:155
本文介绍了如何在树结构可视化中使用CSS连接子项的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我想创建与行相关的项和子项的列表。

I want to create a list of items and sub items that are connected with lines.

到目前为止,我已经完成了此操作-

So far I have done this -

ul {
  list-style: none;
}

ul.sub-menu {
  position: relative;
  padding: 0;
  margin-left: 30px;
  margin-top: 10px;
}

li.item span {
  position: relative;
}

ul.sub-menu li.item span::before {
  content: '';
  height: 100%;
  width: 10px;
  border-bottom: 1px solid #000;
  border-left: 1px solid #000;
  position: absolute;
  bottom: 10px;
  left: -10px;
  z-index: -1;
}

<ul class="main">
  <li class="items">Task 1</li>

  <li class="items">Task 2
    <ul class="sub-menu">
      <li class="item"><span>Sub Task 1</span></li>

      <li class="item"><span>Sub Task 2</span>
        <ul class="sub-menu">
          <li class="item"><span>Sub Task 1</span></li>
          <li class="item"><span>Sub Task 2</span></li>
        </ul>
      </li>

      <li class="item"><span>Sub Task 3</span></li>
    </ul>
  </li>

  <li class="items">Task 3</li>
</ul>

如您所见,子任务3 没有与其父级完全连接。如何连接它?

As you can see, Sub Task 3 is not fully connected with its parent. How to connect this?

注意:我看到了一个问题,此处,并给出了答案。然后我看到了这个问题。

Note: I saw a question here and gave this as an answer. Then I saw this problem was happening.

推荐答案

我会像下面这样做:

.main {
  overflow: hidden;
}
ul {
  list-style: none;
  padding: 0;
  margin-left: 30px;
  margin-top: 10px;
}
.item {
  position: relative;
  line-height: 1.2em;
}
.item::before,
.item::after,
.item:last-child .sub-menu::before{
  content: '';
  background: #000;
  position: absolute;

}
.item::before {
  width: 10px;
  height: 1px;
  top: 0.5em;
  left: -10px;
}

.item::after {
  left: 20px;
  bottom: 0.6em;
  top: 1.2em;
  width: 1px;
}
/* the bekow will avoid the line to go down if there is no sub task (not transparent!)*/
.item:last-child > .sub-menu::before {
  top: calc(0.6em - 1px);
  width: 6px;
  bottom: 0;
  background: #fff;
  left: -12px;
  z-index: 1;
}

<ul class="main">
  <li class="item">Task 1</li>

  <li class="item">Task 2
    <ul class="sub-menu">
      <li class="item">Sub Task 1</li>

      <li class="item">Sub Task 2
        <ul class="sub-menu">
          <li class="item">Sub Task 1</li>
          <li class="item">Sub Task 2</li>
        </ul>
      </li>

      <li class="item">Sub Task 3
        <ul class="sub-menu">
          <li class="item">Sub Task 1</li>
          <li class="item">Sub Task 2
            <ul class="sub-menu">
              <li class="item">Sub Task 1</li>
              <li class="item">Sub Task 2</li>
            </ul>
          </li>
          <li class="item">Sub Task 3</li>
          <li class="item">Sub Task 4</li>
        </ul>
      </li>
    </ul>
  </li>

  <li class="item">Task 3</li>
</ul>

这篇关于如何在树结构可视化中使用CSS连接子项的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆