我有一个小“插入”放在我目前悬停的菜单项上,我现在意识到插入符不是居中。我有一堆动态大小的菜单项。
类menu-caret
在被一点点jquery徘徊时被应用,我有一些像这样的css:
.menu-caret::before {
content:"";
position: absolute;
margin-left: 20px;
bottom: 0;
width: 0%;
height: 0;
border-left: 5px solid transparent;
border-right: 5px solid transparent;
border-bottom: 5px solid black;
}
请点击此处的简短示例 - https://jsfiddle.net/keL4zhky/3/。
是否可以将插入物放在底部?谢谢!
编辑:没有亲戚可以这样做吗?我有一个全宽子菜单,如果我将ul / li更改为亲戚会失去它的效果 - 请参阅此处示例http://codepen.io/ajmajma/pen/KgGxWL
答案 0 :(得分:4)
只需创建父position: relative;
并将left: 50%;
和margin-left: -5px;
添加到伪元素:
ul {
width: 100%;
position: relative;
display: inline-block;
list-style-type: none;
}
li {
padding: 20px;
float: left;
position: relative;
}
.menu-caret::before {
content: "";
position: absolute;
left: 50%;
bottom: 0;
width: 0%;
margin-left: -5px;
height: 0;
border-left: 5px solid transparent;
border-right: 5px solid transparent;
border-bottom: 5px solid black;
}
<ul>
<li class="menu-caret">one</li>
<li class="menu-caret">larger</li>
<li class="menu-caret">larrrrger</li>
</ul>
您可以使用left: 50%;
margin-left: -5px;
和left: calc(50% - 5px);
。
答案 1 :(得分:2)
li
必须position:relative
才能提供定位上下文。
然后将伪元素放置在绝对50%的位置,然后通过变换拉回50%它自己的宽度。这适用于任何尺寸的插入符号,不需要任何幻数。
ul {
width: 100%;
position: relative;
display: inline-block;
list-style-type: none;
}
li {
padding: 20px;
float: left;
}
.menu-caret {
position: relative;
}
.menu-caret::before {
content: "";
position: absolute;
transform: translateX(-50%);
left: 50%;
bottom: 0;
width: 0%;
height: 0;
border-left: 5px solid transparent;
border-right: 5px solid transparent;
border-bottom: 5px solid black;
}
<ul>
<li class="menu-caret">one</li>
<li class="menu-caret">larger</li>
<li class="menu-caret">larrrrger</li>
</ul>
答案 2 :(得分:1)
而不是absolute
定位和float
,我更喜欢:
ul {
width: 100%;
position: relative;
display: inline-block;
list-style-type: none;
}
li {
padding: 20px;
text-align:center;
display: inline-block;
}
.menu-caret::after {
text-align: center;
display: block;
content: "";
border-left: 5px solid transparent;
border-right: 5px solid transparent;
border-bottom: 5px solid black;
clear: both;
width: 1px;
margin: 0 auto;
}
<ul>
<li class="menu-caret">one</li>
<li class="menu-caret">larger</li>
<li class="menu-caret">larrrrger</li>
</ul>