伪元素就像CSS网格中的网格项一样

时间:2017-08-09 19:39:42

标签: html css css3 pseudo-element css-grid

我正在创建一个包含必填字段的表单。要根据需要标记这些,我将一个星号(*)作为::before元素并将其向右浮动,使其位于该字段的右上角。

我遇到的问题是这些字段中的一些是使用CSS网格定位的,当我向网格添加::before元素时,它被视为另一个网格项并将所有内容推送到新网格行。

为什么CSS网格将::before元素视为另一个网格项?如何将星号定位为输入元素?

这是基本的HTML / CSS:

html {
  width: 75%;
}

ul {
  list-style: none;
}

input {
  width: 100%
}

.grid {
  display: grid;
  grid-template-columns: .33fr .33fr .33fr;
}

li.required::before {
  content: '*';
  float: right;
  font-size: 15px;
}
<ul>
  <li class="required">
    <input type="text">
  </li>
  <li class="grid required">
    <p>one</p>
    <p>two</p>
    <p>three</p>
  </li>
  <li class="required">
    <input type="text">
  </li>
</ul>

这是一个小提琴:https://jsfiddle.net/zbqucvt9/

1 个答案:

答案 0 :(得分:6)

伪元素被视为网格容器中的子元素(just like in a flex container)。因此,它们具有网格项的特征。

您始终可以使用绝对定位从文档流中删除网格项。然后使用CSS偏移属性(leftrighttopbottom)来移动它们。

这是一个基本的例子:

&#13;
&#13;
html {
  width: 75%;
}

ul {
  list-style: none;
}

input {
  width: 100%
}

.grid {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
}

li {
  position: relative;
}

li.required::after {
  content: '*';
  font-size: 15px;
  color: red;
  position: absolute;
  right: -15px;
  top: -15px;
}
&#13;
<ul>
  <li class="required">
    <input type="text">
  </li>
  <li class="grid required">
    <p>one</p>
    <p>two</p>
    <p>three</p>
  </li>
  <li class="required">
    <input type="text">
  </li>
</ul>
&#13;
&#13;
&#13;