Angular2: Find out if FormControl has required validator?

前端 未结 7 753
无人共我
无人共我 2020-12-06 08:50

does someone know a way to find out for an Angular2 FormControl if the required validor is registered for the control.

this.form = builder.group({name: [\'\'         


        
相关标签:
7条回答
  • 2020-12-06 09:23

    There is no method how to check validators or get all validators: https://github.com/angular/angular/issues/13461

    @fairlie-agile solution is pretty clever. But I think we have to use empty FormControl because we need fire required validator and this.group.controls[this.config.name] could be already initialized with some value.

    ngOnInit() {
        let formControl = this.group.controls[this.config.name];
        let errors: any = formControl.validator && formControl.validator(new FormControl());
        this._required = errors !== null && errors.required;
    }
    
    0 讨论(0)
  • 2020-12-06 09:36

    One way to do this is to check if the control is valid when the form is loaded to see if it has the required error (which it will if the field is empty).

    This won't work for other validators, such as minLength, as they are not fired until the control is changed

    export class FormInputComponent implements Field, OnInit {
      private _required: boolean;
      config: FieldConfig;
      group: FormGroup;
    
        /** Readonly properties. */
      get required(): boolean { 
        return this._required;
      }
    
      ngOnInit() {
        var _validator: any = this.group.controls[this.config.name].validator && this.group.controls[this.config.name].validator(this.group.controls[this.config.name]);
        this._required = _validator && _validator.required;
      }
    }
    
    0 讨论(0)
  • 2020-12-06 09:38

    While there is no Angular API to directly find if the required validator is set for a particular field, the roundabout way to achieve this is like as below:

    import { NgForm, FormControl } from '@angular/forms';
    
    const isRequiredControl = (formGroup: NgForm, controlName: string): boolean => {
        const { controls } = formGroup
        const control = controls[controlName]
        const { validator } = control
        if (validator) {
            const validation = validator(new FormControl())
            return validation !== null && validation.required === true
        }
        return false
    }
    

    I have tested this and this triggers only if the Validator.Required validator is added to the particular FormControl.

    0 讨论(0)
  • 2020-12-06 09:39

    I have a similar issue. For now, I'm using this:

      import { Attribute } from '@angular/core';
    
      // "Kind-of" hack to allow "pass-through" of the required attribute
      constructor(@Attribute('required') public required) {
        // call super here if the component is an ancestor
      }
    

    I'm really puzzled as to why properties like "disabled" are included in FormControl, but not "required".

    0 讨论(0)
  • 2020-12-06 09:39

    I don't know what's the exact way is to check if control has required validator or not.

    But workaround could be this, Whenever control has required validator, it adds validator() function to that control.

    eg.

    <input type="text" formControlName="firstname">
    
    constructor(private formBuilder: FormBuilder){
        this.registerForm = this.formBuilder.group({
            firstname: ['', Validators.required]     //<<<===one required validation on firstname control
        });
    
        console.log(this.registerForm.controls.firstname.validator.length);
                                                     //<<<===this will return 1.
       });
    

    }

    In above code, length of validator is one(1)


      console.log(this.registerForm.controls.firstname.validator.length);
                                                     //this will return exception
    

    this line will return one. If no validator is attached then firstname will not have validator() function so in that case I'll give an exception.

    DEMO : https://plnkr.co/edit/I7b5JNAavmCJ6Py1eQRr?p=preview

    0 讨论(0)
  • 2020-12-06 09:43

    With the assumption that the only error registered initially is the required error

    // in your component you'll have access to `this.myFormGroup`
    const formGroup = {
      controls: {
        email: {
          errors: {
            required: true
          }
        },
        username: {
          errors: null
        }    
      }
    }
    
    // required by default
    let required = {
      email: '*',
      username: '*',
    };
    
    // in `ngOnInit`
    required = Object.entries(formGroup.controls)
      .map(([key, control]) => [key, control.errors])
      .filter(([, errors]) => !errors)
      .map(([key]) => [key, ''])
      .reduce((_required, [key, isRequired]) => Object.assign(_required, { [key]: isRequired }), required)
    
    // in your template you may write `<label>Email{{ required.email }}</label>`
    console.log(required)

    0 讨论(0)
提交回复
热议问题