angular 2でモデル駆動型フォームを作成しましたが、上のチェックボックスがオフになっている場合にのみ、入力フィールドの1つが表示される必要があります。これは* ngIfで行いました。私の質問はどうすればよいですか。チェックボックスがオフになっている場合にのみ入力が必要になるように設定しますか?In angular 1.xiは、ビューのng-required = "condition"でこれを発生させる可能性があります。
これがhtmlです:
//チェックボックス
<div class="checkbox col-sm-9">
<label>
<input type="checkbox" id="getCompanyAddress" style="cursor: pointer;" [formControl]="form.controls['address']" >Use the company address
</label>
</div>
//オプション入力:
<div *ngIf="form.value.address == false" class="form-group" [ngClass] = "{'has-error':!form.controls['address'].valid && form.controls['address'].touched}" >
<label for="add_gestion_adress" class="col-sm-3 control-label">Address
</label>
<div class="col-sm-9"><textarea rows="1" id="add_gestion_adress" class="form-control" name="add_gestion_adress" [formControl]="form.controls['address']" ></textarea>
</div>
</div>
//およびモデルコード:
form: FormGroup;
constructor(fb:FormBuilder){
this.form = fb.group({
'name': [null,Validators.compose([Validators.required, Validators.minLength(1)])],
'type': ["en gros",Validators.compose([Validators.required, Validators.minLength(2)])],
'person':[null,Validators.compose([Validators.required, Validators.minLength(1)])],
'address':[false,Validators.compose([Validators.minLength(1)])],
'locality':[null, Validators.compose([Validators.required])],
'county':[null,Validators.compose([Validators.required])],
'country':[null,Validators.compose([Validators.required])]
})
}
これを行う1つの方法は、チェックボックスフォームコントロールで値の変更をリッスンし、それに応じて他のコントロールでバリデーターを追加/削除することです。
例:
this.form.get('checkbox-control').valueChanges.map(
value => {
if(value) {
this.form.get('other-control').setValidators(Validators.required);
}else {
this.form.get('other-control').clearValidators();
}
}
);
<textarea [required]="your angular expression">
上記は最新バージョンのAngular 4
FormBuilderは、クロスフィールド検証を目的としたバリデーターを受け入れる2番目の引数を取ります。
_this.form = fb.group({
'name': [null,Validators.compose([Validators.required, Validators.minLength(1)])],
'type': ["en gros",Validators.compose([Validators.required, Validators.minLength(2)])],
'person':[null,Validators.compose([Validators.required, Validators.minLength(1)])],
'address':[false,Validators.compose([Validators.minLength(1)])],
'locality':[null, Validators.compose([Validators.required])],
'county':[null,Validators.compose([Validators.required])],
'country':[null,Validators.compose([Validators.required])]
}
, { validator: this.crossFieldValidation });
_
何でもできるように定義できます。
_crossFieldValidation(ctrl: FormGroup): ValidationErrors|null {
let isRequired = ctrl.controls.myCheckbox.value === true;
let hasValue = ctrl.controls.myMaybeRequiredControlXX.value;
if (isRequired && !hasValue) return {XXrequired: true};
return null;
}
_
Display/ngClassのエラーを確認するには、_form.errors?.XXrequired
_の代わりに、_form.controls.XX.errors?.required
_またはcrossFieldValidation()
が返したキーを使用します。