私のHTMLは必須フィールドに割り当てられている.required
と呼ばれるクラスを持っています。
これがHTMLです。
<form action="/accounts/register/" method="post" role="form" class="form-horizontal">
<input type='hidden' name='csrfmiddlewaretoken' value='brGfMU16YyyG2QEcpLqhb3Zh8AvkYkJt' />
<div class="form-group required">
<label class="col-md-2 control-label">Username</label>
<div class="col-md-4">
<input class="form-control" id="id_username" maxlength="30" name="username" placeholder="Username" required="required" title="" type="text" />
</div>
</div>
<div class="form-group required"><label class="col-md-2 control-label">E-mail</label><div class="col-md-4"><input class="form-control" id="id_email" name="email" placeholder="E-mail" required="required" title="" type="email" /></div></div>
<div class="form-group required"><label class="col-md-2 control-label">Password</label><div class="col-md-4"><input class="form-control" id="id_password1" name="password1" placeholder="Password" required="required" title="" type="password" /></div></div>
<div class="form-group required"><label class="col-md-2 control-label">Password (again)</label><div class="col-md-4"><input class="form-control" id="id_password2" name="password2" placeholder="Password (again)" required="required" title="" type="password" /></div></div>
<div class="form-group required"><label class="col-md-2 control-label">first name</label><div class="col-md-4"><input class="form-control" id="id_first_name" maxlength="30" name="first_name" placeholder="first name" required="required" title="" type="text" /></div></div>
<div class="form-group required"><label class="col-md-2 control-label">last name</label><div class="col-md-4"><input class="form-control" id="id_last_name" maxlength="30" name="last_name" placeholder="last name" required="required" title="" type="text" /></div></div>
<div class="form-group required"><label class="col-md-2 control-label"> </label><div class="col-md-4"><div class="checkbox"><label><input class="" id="id_tos" name="tos" required="required" type="checkbox" /> I have read and agree to the Terms of Service</label></div></div></div>
<div class="form-group">
<div class="col-sm-offset-2 col-sm-10">
<button type="submit" class="btn btn-primary">
<span class="glyphicon glyphicon-star"></span> Sign Me Up!
</button>
</div>
</div>
</form>
私は私のCSSに以下を追加しました。
.form-group .required .control-label:after {
content:"*";color:red;
}
それでも、必須フィールドの周りに赤い*
が表示されません。私はここで何が足りないのですか? Bootstrap 3で必須フィールドに*
を導入する直接的な方法はありませんか?
契約条件の*
は、チェックボックスにすぐには表示されません。これを修正するには?
スペースなしで.form-group.required
を使用してください。
.form-group.required .control-label:after {
content:"*";
color:red;
}
編集する
チェックボックスには、疑似クラスnot()を使用できます。チェックボックスでない限り、各ラベルの後に必要な*を追加します。
.form-group.required:not(.checkbox) .control-label:after, .form-group.required .text:after { /* change .text in whatever class of the text after the checkbox has */ content:"*"; color:red; }
注:未テスト
あなたは.textクラスを使用するか、そうでなければおそらくそれをターゲットにする必要があります、このHTMLを試してみてください:
<div class="form-group required"> <label class="col-md-2 control-label"> </label> <div class="col-md-4"> <div class="checkbox"> <label class='text'> <!-- use this class --> <input class="" id="id_tos" name="tos" required="required" type="checkbox" /> I have read and agree to the Terms of Service </label> </div> </div> </div>
わかりました3番目の編集:
CSSを元に戻しました
.form-group.required .control-label:after {
content:"*";
color:red;
}
HTML:
<div class="form-group required">
<label class="col-md-2"> </label> <!-- remove class control-label -->
<div class="col-md-4">
<div class="checkbox">
<label class='control-label'> <!-- use this class as the red * will be after control-label -->
<input class="" id="id_tos" name="tos" required="required" type="checkbox" /> I have read and agree to the Terms of Service
</label>
</div>
</div>
</div>
これがHTMLの外観であると想定する
<div class="form-group required">
<label class="col-md-2 control-label">E-mail</label>
<div class="col-md-4"><input class="form-control" id="id_email" name="email" placeholder="E-mail" required="required" title="" type="email" /></div>
</div>
ラベルの右側にアスタリスクを表示するには
.form-group.required .control-label:after {
color: #d00;
content: "*";
position: absolute;
margin-left: 8px;
top:7px;
}
またはラベルの左側に:
.form-group.required .control-label:before{
color: red;
content: "*";
position: absolute;
margin-left: -15px;
}
素敵な大きな赤いアスタリスクを作成するには、次の行を追加します。
font-family: 'Glyphicons Halflings';
font-weight: normal;
font-size: 14px;
あるいは、 Font Awesome を使用している場合は、次の行を追加してください(そして内容行を変更してください)。
font-family: 'FontAwesome';
font-weight: normal;
font-size: 14px;
content: "\f069";
.form-group .required .control-label:after
はおそらく.form-group.required .control-label:after
であるはずです。 .form-groupと.requiredの間のスペースの削除は変更です。
他の2つの答えは正しいです。 CSSセレクタにスペースを含めると、子要素がターゲットになります。
.form-group .required {
styles
}
"form-group"クラスの要素の中にある "required"クラスの要素をターゲットにしています。
スペースなしでそれは持っている要素をターゲットにしています 両方 クラス。 '必須'と 'フォームグループ'
このCSSは私のために働きました:
.form-group.required.control-label:before{
color: red;
content: "*";
position: absolute;
margin-left: -10px;
}
そしてこのHTML:
<div class="form-group required control-label">
<label for="emailField">Email</label>
<input type="email" class="form-control" id="emailField" placeholder="Type Your Email Address Here" />
</div>