CSS 家谱没有换行

标签 css

我正在尝试使该 css 插件无需换行即可工作,但失败了。这是tutorial我正在关注。

有什么办法可以让它不换行吗?

它是这样的:https://jsfiddle.net/jhkvpxLg/

* {margin: 0; padding: 0;}
.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 a{
  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 a:hover, 
.tree li a:hover+ul li a {
  background: #c8e4f8; color: #000; border: 1px solid #94a0b4;
}
.tree li a:hover+ul li::after, 
.tree li a:hover+ul li::before, 
.tree li a:hover+ul::before, 
.tree li a:hover+ul ul::before{
  border-color:  #94a0b4;
}
<!--
We will create a family tree using just CSS(3)
The markup will be simple nested lists
-->
<div class="tree">
  <ul>
    <li>
      <a href="#">Parent</a>
      <ul>
        <li>
          <a href="#">Child</a>
          <ul>
            <li>
              <a href="#">Grand Child</a>
            </li>
          </ul>
        </li>
        <li>
          <a href="#">Child</a>
          <ul>
            <li><a href="#">Grand Child</a></li>
            <li>
              <a href="#">Grand Child</a>
              <ul>
                <li>
                  <a href="#">Great Grand Child</a>
                </li>
                <li>
                  <a href="#">Great Grand Child</a>
                </li>
                <li>
                  <a href="#">Great Grand Child</a>
                </li>
              </ul>
            </li>
            <li>
              <a href="#">Grand Child</a>
              <ul>
                <li>
                  <a href="#">Great Grand Child</a>
                </li>
                <li>
                  <a href="#">Great Grand Child</a>
                </li>
                <li>
                  <a href="#">Great Grand Child</a>
                </li>
              </ul>
            </li>
          </ul>
        </li>
      </ul>
    </li>
  </ul>
</div>

最佳答案

  • .tree li 中删除 float:left(不再需要)和
  • display:flex 添加到 .tree ul

fiddle

不要忘记通过 autoprefixer 运行最终的 CSS .

关于CSS 家谱没有换行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42149493/

相关文章:

javascript - 固定div时防止动画跳转

html - 如何在CSS中绘制一 strip 矩形的居中线到一侧

html - 添加第 7 张幻灯片时纯 CSS 幻灯片库出错

html - 如何将包含许多图像的div设置为背景?

html - 无法获取 float :right to work on all elements properly

javascript - 当其他内容大小发生变化时动画 div 位置

html - 如何在CSS中使3列宽度具有不同尺寸的流体

javascript - HTML平滑滚动[没有 anchor 动画]?

html - 如何在 Bootstrap 4 的列中创建响应式多列无序列表?

html - 我的网站在缩放 100%+ 时一团糟