首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >嵌套列表元素上的选择框架的宽度相同

嵌套列表元素上的选择框架的宽度相同
EN

Stack Overflow用户
提问于 2015-07-24 15:59:14
回答 1查看 122关注 0票数 3

我需要使所有嵌套的ul li元素的选择框架宽度相同,就像这个example

也就是说,当鼠标悬停在元素上(整行应该是可点击的)时,左边就没有空格了。我使用AngularJS递归指令来创建这个列表(深度可以改变)。

Here's what I've got now,到目前为止还找不到答案。

我的CSS:

代码语言:javascript
复制
div[data-tree-model] li span:hover {
   background-color: #D7D7D7;
   border: 1px solid #A2A3A6;
   display: block; 
}

div[data-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: #2E9BDB;
   text-decoration: none;
   font-weight: bold;
}
div[data-tree-model] ul {
   margin: 0;
   padding: 0;
   list-style: none;
   overflow: hidden;

}
div[data-tree-model] li {
   position: relative;
   padding: 0 0 0 20px;
}
div[data-tree-model] li span {
   cursor: pointer;
   white-space: nowrap;
   border: 1px solid transparent;
   display: block;
   width: 100%;
}

指令模板:

代码语言:javascript
复制
//tree template
var template =
    '<ul>' +
       '<li data-ng-repeat="node in ' + treeModel + '">' +
          '<span href="#" data-ng-class="{\'selected\': node.selected == true , \'collapsed\': node.' + nodeChildren + '.length && node.collapsed, \'expanded\': node.' + nodeChildren + '.length && !node.collapsed, \'folder\': node.' + nodeChildren + '.length}" data-ng-click="' + treeId + '.selectNodeLabel(node)" title={{node.' + nodeLabel + '}}>{{node.' + nodeLabel + '}}</span>' +
          '<div data-ng-hide="node.collapsed" data-tree-id="' + treeId + '" data-tree-model="node.' + nodeChildren + '" data-node-id=' + nodeId + ' data-node-label=' + nodeLabel + ' data-node-children=' + nodeChildren + '></div>' +
        '</li>' +
     '</ul>';
EN

回答 1

Stack Overflow用户

发布于 2015-07-24 20:16:53

如果树状视图将保持3级深。然后我们就可以做like this了。在你的CSS中,你需要删除下面的填充:

代码语言:javascript
复制
div[data-tree-model] li {
    position: relative;
   //padding: 0 0 0 20px;
}

并且需要添加这个CSS:

代码语言:javascript
复制
div[data-angular-treeview] > ul > li > span {
  padding: 0 0 0 20px;
}
div[data-angular-treeview] > ul > li > div > ul > li > span {
  padding: 0 0 0 40px;
}
div[data-angular-treeview] > ul > li > div > ul > li > div > ul > li > span {
  padding: 0 0 0 60px;
}
div[data-angular-treeview] > ul > li > div > ul > li > div > ul > li > div > ul > li > span {
  padding: 0 0 0 80px;
}

此解决方案适用于通过您的指令创建的当前HTML DOM的3层深度树。:)

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31605158

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档