171

什么是克服此代码无法按预期工作的不幸事实的好方法:

<div class="required">
    <label>Name:</label>
    <input type="text">
</div>

<style>
    .required input:after { content:"*"; }
</style>

在一个完美的世界中,所有 required inputs 都会得到一个小星号,表示该字段是必需的。这个解决方案是不可能的,因为 CSS 是在元素内容之后插入的,而不是在元素本身之后,但类似的东西是理想的。在具有数千个必填字段的站点上,我可以将输入前面的星号移动到一行 ( :afterto :before),或者我可以将它移动到标签的末尾 ( .required label:after) 或标签前面,或者容器上的位置等...

这一点很重要,不仅以防我改变了将星号放置在何处的想法,而且对于表单布局不允许星号位于标准位置的奇怪情况也很重要。它还可以很好地用于检查表单或突出显示未正确完成的控件的验证。

最后,它不会添加额外的标记。

有没有什么好的解决方案具有不可能代码的全部或大部分优点?

4

19 回答 19

310

你是这么想的吗?

http://jsfiddle.net/erqrN/1/

<label class="required">Name:</label>
<input type="text">

<style>
  .required:after {
    content:" *";
    color: red;
  }
</style>

.required:after {
  content:" *";
  color: red;
}
<label class="required">Name:</label>
<input type="text">

请参阅https://developer.mozilla.org/en-US/docs/Web/CSS/pseudo-elements

于 2012-06-25T21:43:27.663 回答
74
.required label {
    font-weight: bold;
}
.required label:after {
    color: #e32;
    content: ' *';
    display:inline;
}

摆弄你的确切结构:http: //jsfiddle.net/bQ859/

于 2013-07-07T08:39:17.217 回答
23

如下图所示,将其完全放入 INTO 输入中:

在此处输入图像描述

我找到了以下方法:

.asterisk_input::after {
content:" *"; 
color: #e32;
position: absolute; 
margin: 0px 0px 0px -20px; 
font-size: xx-large; 
padding: 0 5px 0 0; }
 <form>
    <div>              
        <input type="text" size="15" />                                 
        <span class="asterisk_input">  </span>            
    </div>            
</form> 

我工作的网站是使用固定布局编码的,所以对我来说没问题。

我不确定它是否适合液体设计。

于 2014-05-30T21:34:46.133 回答
15
input[required]{
    background-image: radial-gradient(#F00 15%, transparent 16%), radial-gradient(#F00 15%, transparent 16%);
    background-size: 1em 1em;
    background-position: right top;
    background-repeat: no-repeat;
}
于 2015-10-27T22:53:54.523 回答
14

用 CSS 写

.form-group.required .control-label:after {content:"*";color:red;}

和 HTML

<div class="form-group required">

    <label class="control-label">Name:</label>

    <input type="text">

</div>
于 2017-07-18T06:42:56.490 回答
12
input[required], select[required] {
    background-image: url('/img/star.png');
    background-repeat: no-repeat;
    background-position-x: right;
}

图片右侧有一些 20 像素的空间,不与选择下拉箭头重叠

在此处输入图像描述

它看起来像这样:在此处输入图像描述

于 2014-09-08T04:47:34.537 回答
8

现在是 2019 年,以前对这个问题的答案没有使用

  1. CSS 网格
  2. CSS 变量
  3. HTML5 表单元素
  4. CSS 中的 SVG

CSS 网格是 2019 年创建表单的方式,因为您可以将标签放在输入之前,而无需额外的 div、span、带星号的 span 和其他遗物。

这是我们使用最少 CSS 的地方:

示例截图

上面的 HTML:

<form action="https://www.example.com/register/" method="post" id="form-validate" enctype="multipart/form-data">
    <p class="form-instructions">Please enter the following information to create your account.</p>
    <label for="firstname">First name</label>
    <input type="text" id="firstname" name="firstname" value="" title="First name" maxlength="255" required="">
    <label for="lastname">Last name</label>
    <input type="text" id="lastname" name="lastname" value="" title="Last name" maxlength="255" required="">
    <label for="email_address">Email address</label>
    <input type="email" autocapitalize="off" autocorrect="off" spellcheck="false" name="email" id="email_address" value="" title="Email address" size="30" required="">
    <label for="password">Password</label>
    <input type="password" name="password" id="password" title="Password" required="">
    <label for="confirmation">Confirm password</label>
    <input type="password" name="confirmation" title="Confirm password" id="confirmation" required="">
    <input type="checkbox" name="is_subscribed" title="Subscribe to our newsletter" value="1" id="is_subscribed" class="checkbox">
    <label for="is_subscribed">Subscribe to the newsletter</label>
    <input type="checkbox" name="persistent_remember_me" id="remember_meGCJiRe0GbJ" checked="checked" title="Remember me">
    <label for="remember_meGCJiRe0GbJ">Remember me</label>
    <p class="required">* Required</p>
    <button type="submit" title="Register">Register</button>
</form>

占位符文本也可以添加,强烈推荐。(我只是在回答这个中间形式)。

现在对于 CSS 变量:

--icon-required: url('data:image/svg+xml,\
<svg xmlns="http://www.w3.org/2000/svg" width="100" height="100" viewBox="-10 -6 16 16"> \
  <line id="line" y1="-3" y2="3" stroke="%23df0000" stroke-linecap="butt" transform="rotate(15)"></line> \
  <line id="line" y1="-3" y2="3" stroke="%23df0000" stroke-linecap="butt" transform="rotate(75)"></line> \
  <line id="line" y1="-3" y2="3" stroke="%23df0000" stroke-linecap="butt" transform="rotate(-45)"></line> \
</svg>');

--icon-tick: url('data:image/svg+xml,\
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" width="100" height="100" viewBox="-2 -2 16 16"> \
            <path fill="green" stroke-linejoin="round" d="M2 6L1 7l3 4 7-10h-1L4 8z"/> \
</svg>');

表单元素的 CSS:

input[type=text][required],
input[type=email][required],
input[type=password][required],
input[type=tel][required] {
    background-image: var(--icon-required);
    background-position-x: right;
    background-repeat: no-repeat;
    background-size: contain;
}

input:valid {
    --icon-required: var(--icon-tick);
}

表单本身应该在 CSS 网格中:

form {
    align-items: center;
    display: grid;
    grid-gap: var(--form-grid-gap);
    grid-template-columns: var(--form-grid-template-columns);
    margin: auto;
}

列的值可以设置为1fr auto1fr使用任何内容,例如<p>表单中的标签设置为跨度 1/-1。您可以更改媒体查询中的变量,以便输入框在移动设备上和桌面上的输入框一样全宽。如果您愿意,还可以使用 CSS 变量方法更改移动设备上的网格间隙。

当这些框有效时,您应该得到一个绿色的勾号而不是星号。

CSS 中的 SVG 是一种让浏览器不必往返于服务器以获取星号图像的方法。通过这种方式你可以微调星号,这里的例子是在一个不寻常的角度,你可以把它编辑掉,因为上面的 SVG 图标是完全可读的。也可以修改视图框以将星号放置在中心上方或下方。

于 2019-03-01T16:19:17.603 回答
5

使用 jQuery 和 CSS

jQuery(document).ready(function() {
 jQuery("[required]").after("<span class='required'>*</span>");
});
.required {
    position: absolute;
    margin-left: -10px;
    color: #FB0000;
    font-size: 15px;
}
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<input type="text" value="xxx" required>

于 2016-01-27T04:50:26.087 回答
5

我认为这是有效的方法,为什么这么头痛

    <div class="full-row">
     <label for="email-id">Email Address<span style="color:red">*</span></label>
  <input type="email" id="email-id" name="email-id"  ng-model="user.email" >
    </div> 
于 2016-11-07T07:36:26.623 回答
4

这是一个简单的“仅 CSS ”技巧,我创建并使用它在所需表单元素的标签上动态添加红色星号,而不会丢失浏览器的默认表单验证。

以下代码在所有浏览器和所有主要表单元素上都能完美运行。

.form-group {
  display: flex;
  flex-direction: column;
}

label {
  order: 1;
  text-transform: capitalize;
  margin-bottom: 0.3em;
}

input,
select,
textarea {
  padding: 0.5em;
  order: 2;
}

input:required+label::after,
select:required+label::after,
textarea:required+label::after {
  content: " *";
  color: #e32;
}
<div class="form-group">
  <input class="form-control" name="first_name" id="first_name" type="text" placeholder="First Name" required>
  <label class="small mb-1" for="first_name">First Name</label>
</div>

<br>

<div class="form-group">
  <input class="form-control" name="last_name" id="last_name" type="text" placeholder="Last Name">
  <label class="small mb-1" for="last_name">Last Name</label>
</div>

重要提示: 您必须保留元素的顺序,即首先是输入元素,其次是标签元素。CSS 将以传统方式处理和转换它,即首先是标签,然后是输入。

于 2020-09-07T04:26:10.980 回答
2

如果您使用“浮动标签”(如https://css-tricks.com/float-labels-css/https://dev.to/adrianbdesigns/let-s-create-a-floating-label-input -with-html-and-css-only-4mo8)然后你可以使用这个:

input[required]+label:after {
    content: '*';
    color: red;
}

简单,没有图像,不会丢失用户的眼睛。从理论上讲,:after如果您希望标签和星号之间有一些间距,您也可以填充。如果你愿意,你也可以使用:before代替。:after

于 2021-05-12T16:06:56.343 回答
2

如果您在带有必需属性的某个标签内有一个带有字段名称的标签,则以角度形式的常见场景会自动将此属性添加到必填字段

[required] label::after {
  content: '*';
  font-size: 24px;
  line-height: 0;
  vertical-align: middle;
}
于 2021-06-17T09:38:03.830 回答
1

.asterisc {
  display: block;
  color: red;
  margin: -19px 185px;
}
<input style="width:200px">
<span class="asterisc">*</span>

于 2016-02-26T12:00:37.807 回答
0

此示例在标签前面放置一个星号,以将该特定输入表示为必填字段。我使用 % 和 em 设置 CSS 属性以确保我的网页具有响应性。如果您愿意,可以使用 px 或其他绝对单位。

#name {
   display: inline-block;
   margin-left: 40%;
   font-size:25px;
    
}
.nameinput{
   margin-left: 10px;
   font-size:90%;
   width: 17em;
   
}

.nameinput::placeholder {
  font-size: 0.7em;
  vertical-align: middle;
}

#name p{
   margin:0;
   border:0;
   padding:0;
   display:inline-block;
   font-size: 40%;
   vertical-align: super;
}
<label id="name" value="name">
<p>*</p> 
Name:  <input class="nameinput" type="text" placeholder="Enter your name" required>
</label>

于 2019-10-19T02:36:08.240 回答
0

您需要的是 :required 选择器 - 它将选择所有具有 'required' 属性的字段(因此无需添加任何其他类)。然后 - 根据您的需要设置输入样式。您可以使用 ':after' 选择器并按照其他答案中建议的方式添加星号

于 2019-12-10T00:46:26.253 回答
0

可能有很多可能性。您可以反转并使用您喜欢flex-direction的属性,如下所示:requiredinput

fieldset {
    border: none;
    padding: 0;
    display: flex;
    flex-direction: column-reverse;
}
fieldset p {
    margin-bottom: 4px;
}
fieldset input[required] ~ p:after {
    content: '*';
    color: red;
    font-size: 12px;
    margin-left: 4px;
}
<form>
    <fieldset>
        <input type="text" placeholder="Severus" name="first_name" required />
        <p>First Name</p>
    </fieldset>
    <fieldset>
        <input type="text" placeholder="Snape" name="last_name" />
        <p>Last Name</p>
    </fieldset>
</form>

于 2021-12-15T00:00:17.970 回答
-1

您可以通过将 HTML 代码封装在包含“必需”类后跟“表单组”类的 div 标记中来实现所需的结果。*但是这只有在您有 Bootstrap 时才有效。

<div class="form-group required">
    <div class="required">
        <label>Name:</label>
        <input type="text">
    </div>
  <div>
于 2015-12-17T19:57:39.670 回答
-2

对于那些最终来到这里但拥有 jQuery 的人:

// javascript / jQuery
$("label.required").append('<span class="red-star"> *</span>')

// css
.red-star { color: red; }
于 2016-01-07T21:54:34.133 回答
-2

简单而简短

<label>Name:<span class="required">*</span></label>

.required {
    color: red;
  }
于 2021-03-03T12:20:42.253 回答