Maison >interface Web >js tutoriel >Une brève analyse de la façon d'utiliser FormArray et les boîtes modales dans Angular

Une brève analyse de la façon d'utiliser FormArray et les boîtes modales dans Angular

青灯夜游
青灯夜游avant
2022-12-20 21:23:062071parcourir

Comment utiliser FormArray et la boîte modale ensemble ? L'article suivant vous présentera comment utiliser ensemble le FormArray et la boîte modale de Angular. J'espère que cela vous sera utile !

Une brève analyse de la façon d'utiliser FormArray et les boîtes modales dans Angular

Scénario commercial

Utilisez FormArray pour créer des formulaires dynamiques. Chaque fois qu'un formulaire est créé, une nouvelle entrée est ajoutée à la page pour afficher le titre du formulaire. Cliquez sur Modifier et cliquez sur le contenu à remplir du formulaire. [Tutoriels associés recommandés : "Tutoriel angulaire"]

    // 封装获取modelList
    get modelList() {
        return this.formGroup.get('modelList') as FormArray
    }
    constructor(private fb: FormBuilder) {}
    ngOnInit() {
        // 一开始初始化arr为空数组
        this.formGroup = this.fb.group({
            // 内部嵌套FormControl、FormArray、FormGroup
            modelList: this.fb.array([])
        })
    }
    // 模态框构造内部的表单
    function newModel() {
        return this.fb.group({
            modelName: [''],
            // 可以继续嵌套下去,根据业务需求
        })
    }
    // 省略模态框部分代码
    // 传递到模态框的FormArray
    selectedType: FormArray

Liste de formulaires

Une brève analyse de la façon dutiliser FormArray et les boîtes modales dans Angular

Détails du formulaire [Boîte modale]

Une brève analyse de la façon dutiliser FormArray et les boîtes modales dans Angular

<form [FormGroup]="formGroup">
    <div FormArrayName="modelList">
        <ng-container *nfFor="let item of modelList.controls;let i = index" [FormGroupName]="i">
            <nz-input-group
                [nzSuffix]="suffixIconSearch"
              >
                <input type="text" nz-input formControlName="modelName"/>
              </nz-input-group>
              <ng-template #suffixIconSearch>
                <span
                  nz-icon
                  nzType="edit"
                  class="hover"
                  (click)="showModal(i)"
                ></span>
              </ng-template>
        </ng-container>
    </div>
</form>
<nz-modal
  [(nzVisible)]="isVisible"
  nzTitle="Model"
  [nzFooter]="modalFooter"
  (nzOnCancel)="handleCancel()"
  (nzOnOk)="handleOk()"
>
  <ng-container *nzModalContent>
    <form nz-form [formGroup]="selectedType">
      <nz-form-item>
        <nz-form-label nzRequired>Model Test</nz-form-label>
        <nz-form-control>
          <input
            type="text"
            nz-input
            placeholder="请输入ModelName"
            formControlName="modelName"
          />
        </nz-form-control>
      </nz-form-item>
      <nz-form-item>
        <nz-form-control>
          <product-config></product-config>
        </nz-form-control>
      </nz-form-item>
    </form>
  </ng-container>
  <ng-template #modalFooter>
    <button *ngIf="!isNewModel" nzDanger nz-button nzType="default" (click)="handleDelete()">删除</button>
    <button *ngIf="isNewModel" nz-button nzType="default" (click)="handleCancel()">取消</button>
    <button nz-button nzType="primary" (click)="handleOk()">保存</button>
  </ng-template>
</nz-modal>

Parce que ce type de boîte modale est spécial et divisé La relation entre le FormGroup du formulaire. Lorsque vous cliquez, vous devez passer des paramètres à la boîte modale pour afficher une partie de la valeur. Si vous transmettez simplement des paramètres, utilisez this.modelList.at(index) pour obtenir. l'entité dans la boîte modale. Après avoir modifié l'affectation et cliqué sur Enregistrer dans la boîte modale, vous constaterez que la valeur modifiée n'est pas mise à jour dans le formulaire, et la modification de la valeur d'entrée sur le formulaire affectera le contenu de la boîte modale. this.modelList.at(index)获取实体到模态框上进行赋值修改,在模态框点击保存后会发现修改的值没有在表单更新,而表单上对input值修改发现可以影响到模态框的内容。

但是模态框新增的表单却可以响应到页面中去。

原错误代码思路

  • 点击编辑后,将点击的FormArray的元素传递给一个临时变量 this.selectedType = <formgroup>this.modelList.at(index);</formgroup>

    Mais le formulaire ajouté dans la zone modale peut être répondu à la page.
  • Idée de code d'erreur originale


Après avoir cliqué sur Modifier, transmettez l'élément FormArray cliqué à une variable temporaire this.selectedType = <formgroup>this .modelList .at(index);</formgroup> et transmettez la valeur au formulaire de boîte modale.
  • Cliquez sur Enregistrer dans la zone modale et remplacez la valeur du FormArray d'origine
  • this.modelList.removeAt(this.modelIndex)
    this.modelList.insert(this.modelIndex, this.selectedType)

Cliquez sur Ajouter pour créer un nouvel objet FormGroup

Enregistrez et ajoutez un push au FormArray de la page d'origineUne brève analyse de la façon dutiliser FormArray et les boîtes modales dans Angular

newModelType(): FormGroup {
    return this.fb.group({
      modelName: [&#39;&#39;, Validators.required],
      configList: this.fb.array([]),
    });
  }
// ...省略
// 模态框显示
show() {
    this.isVisible = true
    this.selectedType = this.newModelType();
}
// 保存
save() {
    this.isVisible = false
    // 原页面FormArray
    this.modelList.push(this.selectedType);
}

Enfin, j'ai découvert que cette méthode d'écriture ne peut changer que dans un sens. La modification de la valeur d'entrée en dehors de la page affectera la boîte modale, mais le changement de valeur de la boîte modale ne sera pas mis à jour en externe. La vérification des paramètres internes du FormArray de la page via la méthode console a révélé qu'il y avait effectivement des changements, mais Angular ne l'a pas détecté. À l'heure actuelle, on estime que la raison pour laquelle il n'y a pas de réponse est généralement que le mécanisme de détection angulaire n'est pas déclenché. Après avoir soigneusement vérifié le document, j'ai découvert qu'il y avait une ligne très importante

document angulaireUne brève analyse de la façon dutiliser FormArray et les boîtes modales dans Angular écrite en bas

.

Lorsque je l'ai lu pour la première fois, j'ai senti que je m'y conformais. Ce principe est suivi car lors de l'édition, j'ai choisi de manipuler le FormArray original pour supprimer et insérer des éléments. à la boîte modale a violé ce principe. Lorsque j'ai attribué des valeurs, j'ai pris l'instance d'élément de FormArray et je l'ai assignée à la variable temporaire de la boîte modale, puis j'ai modifié la valeur de l'instance et supprimé à nouveau l'insertion. fonctionnant sur la même instance, donc Angular n'a pas détecté le changement [bien que la valeur ait changé]

Alors, quelle est la bonne approche ? ?

Ne soyez pas paresseux lors de l'attribution de valeurs. Vous devez toujours recréer un nouvel objet, puis obtenir la valeur attribuée à l'objet d'origine. [Équivalent à la copie profonde]

      this.selectedType = this.newModelType();
      const old = this.modelList.at(index);
      this.selectedType.setValue({
        &#39;modelName&#39;: old.get(&#39;modelName&#39;).value
    })

Vous pouvez mettre à jour normalement à ce moment.

Résumé🎜🎜🎜En fait, au final, il s'agissait essentiellement d'un retour à la documentation. Il existe également de nombreux pièges dans les erreurs de dépannage, et il n'y a pratiquement aucun article angulaire en Chine, nous devons donc nous appuyer sur des forums externes pour trouver des problèmes. 🎜🎜Pour plus de connaissances liées à la programmation, veuillez visiter : 🎜Enseignement de la programmation🎜 ! ! 🎜

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Cet article est reproduit dans:. en cas de violation, veuillez contacter admin@php.cn Supprimer