中心psuedo元素内容

时间:2016-10-18 19:33:07

标签: html css

我有一个小“插入”放在我目前悬停的菜单项上,我现在意识到插入符不是居中。我有一堆动态大小的菜单项。

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

3 个答案:

答案 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>