casilla de verificación eng privilegiada con forma reactiva con array

votos
0

Estoy tratando de añadir mi serie de objetos para asignar la casilla eng primer y me gustaría obtener los valores de las casillas seleccionadas.

He tratado FormControlName pero que está lanzando indefinido después de la presentación.

a continuación es el código en bruto

data = [
    { type: dropdown
      text: 'drop',
      num: 1.23,
      options: [
      {
       value=1,
       text= 'drop1
      },{
       value=2,
       text= 'drop2
      }
      ]
    },
    { type: checkbox
      text: 'check',
      num: 1.23,
      options: [
      {
       value=1,
       text= 'check1
      },{
       value=2,
       text= 'check2
      }
      ]
    },
    { type: radio
      text: 'radio',
      num: 1.23,
      options: [
      {
       value=1,
       text= 'radio1
      },{
       value=2,
       text= 'radio2
      }
      ]
    },
  ];
<form [formGroup]=group>
 
  <div *ngFor=let d of data>
  <div *ngSwitchCase = checkbox>
    <p-checkbox *ngFor=let check of options  [value]=check.value [formControlName]=check.text></p-checkbox>
    </div>
    <div *ngSwitchCase = dropdown>
  <p-dropdown *ngFor=let drop of options [value]=drop.value [formControlName]=d.text> {{drop.text}}
   </p-dropdown>
  </div>
   <div *ngSwitchCase = radio>
    <p-radioButton  *ngFor=let radio of options[value]=radio.value [formControlName]=d.text></p-radioButton >
  </div>
  </div>
 </form>

¿Cómo puedo obtener la referencia de mi control y valores de la misma para desplegable y casillas de verificación.

Cómo obtener los valores para las formas dinámicas?

Publicado el 14/02/2020 a las 00:01
fuente por usuario
En otros idiomas...                            


1 respuestas

votos
2

para dinámico forma primera cosa reactiva tenemos para generar la base formGroup de los datos de control de formulario

método getFormGroup devolverá un objeto formGroup por bucle sobre los datos y crear una forma de controles con base de nombre del textvalor.

getFormGroup() {

    const formControls = this.data.reduce( (controls , f:FormControl)=>{

      controls[f.text] = this.formBuilder.control(null);
      return controls;

    },{});

    return this.formBuilder.group(formControls)
  }

después de generar la forma que ahora podemos hacer que los controles de formulario en la plantilla

<form [formGroup]="form">

    <div *ngFor="let d of data">

        <ng-container [ngSwitch]="d.type">

            <label for="">{{d.text}}</label>
            <div *ngSwitchCase="'checkbox'">
                <p-checkbox *ngFor="let check of d.options" [label]="check.label" [value]="check.value"
                    [formControlName]="d.text"></p-checkbox>
            </div>

            <div *ngSwitchCase="'dropdown'">
                <p-dropdown [options]="d.options" [formControlName]="d.text">
                </p-dropdown>
            </div>

            <div *ngSwitchCase="'radio'">

                <p-radioButton *ngFor="let radio of d.options" [name]="d.text" [label]="radio.label"
                    [value]="radio.value" [formControlName]="d.text">
                </p-radioButton>

            </div>

        </ng-container>
    </div>
</form>

demostración 🚀

Respondida el 17/02/2020 a las 01:21
fuente por usuario

Cookies help us deliver our services. By using our services, you agree to our use of cookies. Learn more