如何使用 CSS、HTML 和一些 Javascript 显示二叉搜索树?

问题描述 投票:0回答:2

我想使用 CSS 和 HTML 在屏幕上“绘制”树,而不是以任何方式或数据结构表示它......

javascript html css binary-search-tree
2个回答
30
投票

CSS 无限二叉树和单层树:

.tree ul {
  padding-top: 20px;
  position: relative;
  transition: all 0.5s;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
}

.tree li {
  float: left;
  text-align: center;
  list-style-type: none;
  position: relative;
  padding: 20px 5px 0 5px;
  transition: all 0.5s;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
}

.tree li::before,
.tree li::after {
  content: '';
  position: absolute;
  top: 0;
  right: 50%;
  border-top: 1px solid #ccc;
  width: 50%;
  height: 20px;
}

.tree li::after {
  right: auto;
  left: 50%;
  border-left: 1px solid #ccc;
}

.tree li:only-child::after,
.tree li:only-child::before {
  display: none;
}

.tree li:only-child {
  padding-top: 0;
}

.tree li:first-child::before,
.tree li:last-child::after {
  border: 0 none;
}

.tree li:last-child::before {
  border-right: 1px solid #ccc;
  border-radius: 0 5px 0 0;
  -webkit-border-radius: 0 5px 0 0;
  -moz-border-radius: 0 5px 0 0;
}

.tree li:first-child::after {
  border-radius: 5px 0 0 0;
  -webkit-border-radius: 5px 0 0 0;
  -moz-border-radius: 5px 0 0 0;
}

.tree ul ul::before {
  content: '';
  position: absolute;
  top: 0;
  left: 50%;
  border-left: 1px solid #ccc;
  width: 0;
  height: 20px;
}

.tree li div {
  border: 1px solid #ccc;
  padding: 5px 10px;
  text-decoration: none;
  color: #666;
  font-family: arial, verdana, tahoma;
  font-size: 11px;
  display: inline-block;
  border-radius: 5px;
  -webkit-border-radius: 5px;
  -moz-border-radius: 5px;
  transition: all 0.5s;
  -webkit-transition: all 0.5s;
  -moz-transition: all 0.5s;
}

.tree li div:hover,
.tree li div:hover+ul li div {
  background: #c8e4f8;
  color: #000;
  border: 1px solid #94a0b4;
}

.tree li div:hover+ul li::after,
.tree li div:hover+ul li::before,
.tree li div:hover+ul::before,
.tree li div:hover+ul ul::before {
  border-color: #94a0b4;
}
<div class="tree">
  <ul>
    <li>
      <div><input type="checkbox"> Main <br/> <button> Test Btn </button></div>
      <ul>
        <li>
          <div><input type="checkbox"> Sub-1</div>
        </li>
        <li>
          <div><input type="checkbox"> Sub-2</div>
          <ul>
            <li>
              <div><input type="checkbox"> Sub-2-1</div>
            </li>
            <li>
              <div><input type="checkbox"> Sub-2-2</div>
            </li>
          </ul>
        </li>
      </ul>
    </li>
  </ul>
</div>

也可以在这个jsfiddle

上找到

2
投票

使用 HTML 和 CSS 创建树状结构的非常简单的方法是嵌套

<div>
s
每个
div
代表一个节点,内部可以有多个节点:

<div> //root
    <div> //child 1
        <div> //child 1.1
            <div></div> //child 1.1.1
            <div></div> //child 1.1.2
            <div></div> //child 1.1.3
        </div>
        <div></div> //child 1.2
    </div>
    <div></div> //child 2
</div>

然后你可以给所有div添加一个

margin-top
,这样它们就会出现在其父div下面。

JSFiddle:http://jsfiddle.net/VxRmc/

我为每个 div 添加了百分比宽度。如果您知道一个节点有多少个子节点,则可以计算宽度。或者您可以使用固定宽度...

是的,这不是一棵美丽的树,但它再简单不过了。

© www.soinside.com 2019 - 2024. All rights reserved.