6

我的 django ModelForm 中有一些必要的字段。如何在必填字段后添加红星 (*)?

4

2 回答 2

28

我将假设您希望这自动发生,所以这里有几种不同的方法之一:

{% for field in form %}
    <label for="{{ field.auto_id }}">{{ field.label_tag }}
    {% if field.field.required %}
        <span class="required">*</span>
    {% endif %}
    </label>
{% endfor %}

然后,您可以使用 CSS 设置星号样式。

或者,您可以根据需要使用 CSS 添加星号:

<style type="text/css">
    span.required:after { content: '*'; }
</style>
{% for field in form %}
    <label for="{{ field.auto_id }}">
    {% if field.field.required %}
        <span class="required">{{ field.label_tag }}</span>
    {% else %}
        {{ field.label_tag }}
    {% endif %}
    </label>
{% endfor %}

如果您还想对必填字段做其他事情,这可能是一个更好的选择。

但是,如果您不会单独访问这些字段(例如使用 {{ form.as_p }}),那么您可以向您的 ModelForm 添加一个属性:

class FooForm(forms.ModelForm):
    required_css_class = 'required'

这会将所有需要的字段定义为具有“必需”类(因此,您可以使用我上面提到的 CSS 代码来添加星号(或您想用它做的任何其他事情)。

于 2012-09-02T10:40:01.973 回答
1

您也可以使用jQuery来选择标签或附加到它。

例如,如果你有这个引导表单

<form class="form-horizontal">
  <div class="form-group">
    <label for="inputEmail3" class="col-sm-2 control-label">Email</label>
    <div class="col-sm-10">
      <input type="email" class="form-control" id="inputEmail3" required="required">
    </div>
  </div>
  <div class="form-group">
    <label for="inputPassword3" class="col-sm-2 control-label">Password</label>
    <div class="col-sm-10">
      <input type="password" class="form-control" id="inputPassword3">
    </div>
  </div>
</form>

然后,如果您想将星号添加到必填字段。

$('input,textarea,select').filter('[required]').parent().parent().find("label").append("*");

此外,您可能希望为必填字段标签指定一个类,以便将它们设为粗体或其他内容

$('input,textarea,select').filter('[required]:visible').parent().parent().find("label").addClass("required_label");
于 2015-04-13T20:38:53.937 回答