gpt4 book ai didi

带剥离背景的 HTML 树

转载 作者:可可西里 更新时间:2023-11-01 13:45:43 26 4
gpt4 key购买 nike

我试图创建一棵像这张图片一样的树。但我无法修复特定行的条纹。减小浏览器大小时,背景条纹无法针对特定 li 修复。我正在为此使用 Angular 树库https://jsfiddle.net/shibincc/npLjrt66/ 中提供的代码示例

            <i class="glyphicon glyphicon-triangle-bottom" ng-show="(node[childNodeLabel].length || !node.isLeafNode) &amp;&amp; !node.collapsed" ng-click="selectNodeHead(node)"></i>
    <i class="glyphicon glyphicon-stop ng-hide" ng-hide="node[childNodeLabel].length || !node.isLeafNode"></i>
    <i class="node-type JOB" ng-mouseleave="onMouseRemove(node,$event)" ng-mouseover="onMouseOver(node,$event)" ng-click="selectNodeLabel(node)"></i>
    <span ng-class="node.selected" ng-click="selectNodeLabel(node)" ng-mouseleave="onMouseRemove(node,$event)" ng-mouseover="onMouseOver(node,$event)" class="ng-binding">Job 2</span>

    </span>
    <section class="fokker-tree" style="font-size: 14px;font-size: 14px" ng-hide="node.collapsed" tree-config="treeConfig" tree-data="node[childNodeLabel]">
    <ul>
    <li ng-repeat="node in treeData track by $index" class="overflow-ellipsis" ng-if="node.nodeType">
    <span ng-if="node.nodeType == 'data'" class="ng-scope">

    <i class="glyphicon glyphicon-triangle-bottom" ng-show="(node[childNodeLabel].length || !node.isLeafNode) &amp;&amp; !node.collapsed" ng-click="selectNodeHead(node)"></i>
    <i class="glyphicon glyphicon-stop ng-hide" ng-hide="node[childNodeLabel].length || !node.isLeafNode"></i>
    <i class="node-type JOB" ng-mouseleave="onMouseRemove(node,$event)" ng-mouseover="onMouseOver(node,$event)" ng-click="selectNodeLabel(node)"></i>
    <span ng-class="node.selected" ng-click="selectNodeLabel(node)" ng-mouseleave="onMouseRemove(node,$event)" ng-mouseover="onMouseOver(node,$event)" class="ng-binding">Job 2</span>

    </span>
    <section class="fokker-tree" style="font-size: 14px;font-size: 14px" ng-hide="node.collapsed" tree-config="treeConfig" tree-data="node[childNodeLabel]">

    </section>

    </li>
    </ul>
    </section>

    </li>

Sample tree image

最佳答案

您可以使用 linear-gradient实现剥离背景。

background-size: auto 4em;
background-origin: content-box;
background-image: linear-gradient(rgba(0,0,0,.2) 50%, transparent 0);

div[angular-treeview] {
/* prevent user selection */
-moz-user-select: -moz-none;
-khtml-user-select: none;
-webkit-user-select: none;
-ms-user-select: none;
user-select: none;

/* default */
font-family: Tahoma;
font-size:13px;
color: #555;
text-decoration: none;
}

div[tree-model] ul {
margin: 0;
padding: 0;
list-style: none;
border: none;
overflow: hidden;
}

div[tree-model] li {
position: relative;
padding: 0 0 0 20px;
line-height: 20px;
}

div[tree-model] li .expanded {
padding: 1px 10px;
background-image: url("http://cfile23.uf.tistory.com/image/205B973A50C13F4B19D9BD");
background-repeat: no-repeat;
}

div[tree-model] li .collapsed {
padding: 1px 10px;
background-image: url("http://cfile23.uf.tistory.com/image/1459193A50C13F4B1B05FB");
background-repeat: no-repeat;
}

div[tree-model] li .normal {
padding: 1px 10px;
background-image: url("http://cfile23.uf.tistory.com/image/165B663A50C13F4B196CCA");
background-repeat: no-repeat;
}

div[tree-model] li i, div[tree-model] li span {
cursor: pointer;
}

div[tree-model] li .selected {
background-color: #aaddff;
font-weight: bold;
padding: 1px 5px;
}


.f-tree {
/* prevent user selection */
-moz-user-select: -moz-none;
-khtml-user-select: none;
-webkit-user-select: none;
-ms-user-select: none;
user-select: none;
}

ul.f-tree {
margin: 0;
padding: 0;
list-style: none;
border: none;
overflow: hidden;
}

.f-tree li {
position: relative;
padding: 5px 0 0 20px;
line-height: 20px;
}

.f-tree li .expanded {
padding: 1px 10px;
background-image: url("http://cfile23.uf.tistory.com/image/205B973A50C13F4B19D9BD");
background-repeat: no-repeat;
}

.f-tree li .collapsed {
padding: 1px 10px;
background-image: url("http://cfile23.uf.tistory.com/image/1459193A50C13F4B1B05FB");
background-repeat: no-repeat;
}

.f-tree li .normal {
padding: 1px 10px;
background-image: url("http://cfile23.uf.tistory.com/image/165B663A50C13F4B196CCA");
background-repeat: no-repeat;
}

.f-tree li i, .f-tree li span {
cursor: pointer;
}

.f-tree li .selected {
background-color: #aaddff;
font-weight: bold;
padding: 1px 5px;
}

.f-tree .node-type{
background-image: url("../list.png");
padding: 1px 10px;
background-repeat: no-repeat;
background-size: contain;
padding: 1px 13px;
}


.f-tree .load-more{
cursor : pointer;
}

.f-tree{
position: relative;
margin:0 0 0 1em; /* indentation */
padding:0;
/*background: #000*/
}

.f-tree:before{
content:"";
display:block;
width:0;
position:absolute;
top:0;
bottom:0;
left:7px;
border-left:1px dotted #BBB;
}

.f-tree li{
margin:0;
padding:0; /* indentation + .5em */
line-height:2em; /* default list item's `line-height` */
font-weight:bold;
position:relative;
}
.f-tree li .node-label{
padding-left: 2em;

}
.inner-tree li{
padding:0 2em;
}

.inner-tree li .node-label{
padding-left: 0;

}

.f-tree li:before {
content:"";
display:block;
width:20px; /* same with indentation */
height:0;
border-top:1px dotted #BBB;
margin-top:-1px; /* border top width */
position:absolute;
top:1em; /* (line-height/2) */
left:7px;
}

.parent-node{
position: absolute;
height: 19px;
left: 0px;
top:2px;

background: url("../folder.png")
}

.f-tree:nth-child(2){
background: #fff
}

.wrapper{
background-size: auto 4em;
background-origin: content-box;
background-image: linear-gradient(rgba(0,0,0,.2) 50%, transparent 0);
}
<ul class="tree-list f-tree wrapper" tree-config="treeConfig" tree-data="treeData">
<li class="tree-node">
<i class="node-type parent-node"></i>
<span class="node-label">content 1</span>
<ul class="inner-tree tree-list f-tree ">
<li class="tree-node">
<i class="node-type" ></i>
<span class="node-label">Content 1.1</span>
<ul class="inner-tree tree-list f-tree ">
<li class="tree-node">
<i class="node-type"></i>
<span class="node-label">Content 1.1.1</span>
<ul class="inner-tree tree-list f-tree ">
<li class="tree-node">
<i class="node-type"></i>
<span class="node-label">Content 1.1.1.1</span>
<ul class="inner-tree tree-list f-tree ">
</ul>
</li>
</ul>
</li>
</ul>
</li>
<li class="tree-node">
<i class="node-type"></i>
<span class="node-label">Content 1.2</span>
<ul class="inner-tree tree-list f-tree ">
<li class="tree-node">
<i class="node-type"></i>
<span class="node-label">Content 1.2.1</span>
<ul class="inner-tree tree-list f-tree ">
<li class="tree-node">
<i class="node-type"></i>
<span class="node-label">Content 1.2.1.1</span>
<ul class="inner-tree tree-list f-tree ">
</ul>
</li>
<li class="tree-node">
<i class="node-type"></i>
<span class="node-label">Content 1.2.1.2</span>
<ul class="inner-tree tree-list f-tree ">
</ul>
</li>
</ul>
</li>
</ul>
</li>
</ul>
</li>
<li class="tree-node">
<i class="node-type parent-node"></i>
<span class="node-label">content 2</span>
<ul class="inner-tree tree-list f-tree ">
<li class="tree-node">
<i class="node-type"></i>
<span class="node-label">Content 2.1</span>
<ul class="inner-tree tree-list f-tree ">
</ul>
</li>
</ul>
</li>
<li class="tree-node">
<i class="node-type parent-node"></i>
<span class="node-label">content 3</span>
<ul class="inner-tree tree-list f-tree "></ul>
</li>
</ul>

关于带剥离背景的 HTML 树,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43862770/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com