动态添加未呈现

问题描述 投票:0回答:1

我有一个字符串,其中包含我想要动态呈现的表单。

当用户单击“添加步骤”时,我的模板字符串将添加到列表中并使用ngFor进行渲染。问题是输入不呈现,只有<h3>标记。

点击按钮之前:

enter image description here

之后 - 屏幕上或html中没有呈现任何输入:

enter image description here

TS:

scenarioTemplate = `
  <div id="content">
    <h3>Name</h3>
    <input name="{{i}}" [ngModel]="i">
  </div>`;

steps = [];

addScenarioStep() {
    this.steps.push(this.scenarioTemplate);
}

HTML:

<form #myForm="ngForm">
  <fieldset ngModelGroup="inputs" #inputs="ngModelGroup">
    <ng-container *ngFor="let step of steps; let i = index">
      <div [innerHTML]=step attr.stepId="{{i}}"></div>
    </ng-container>
  </fieldset>
</form>
<button id="addStepBtn" type="button" class="btn btn-light" (click)="addScenarioStep()">Add Scenario Step +</button>
javascript angular typescript
1个回答
0
投票
  1. 把那整件事
  <div id="content">
    <h3>Name</h3>
    <input name="{{i}}" [ngModel]="i">
  </div>

在模板中,而不是TS。

  1. 不要改变数组。代替
this.steps.push(newElem);

this.steps = [...this.steps, newElem];
© www.soinside.com 2019 - 2024. All rights reserved.