微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

从 TS 代码更改 mat-slide-toggle 值

如何解决从 TS 代码更改 mat-slide-toggle 值

我有这样的用于 mat-slide-toggle 元素的 HTML 代码

<span class="form-control form-control-plaintext">
              <mat-slide-toggle name="status" checked=""
                              formControlName="status" #status>
              <label *ngIf="!formGroup.get('status').value" (click)="toggleStatus(status)" style="margin: 0">Status: disabled</label>
              <label *ngIf="formGroup.get('status').value" (click)="toggleStatus(status)" style="margin: 0">Status: Active</label>
            </mat-slide-toggle>
</span>

这是在toggleStatus()函数

toggleStatus(status) {
    status.checked = !status.checked;
}

这工作正常,但仅适用于可视复选框,它不会更改表单控件值。 单击标签时如何更改表单控件值?

解决方法

您可以通过表单控件更改表单控件的值。

  public changeValueThroughFormControl(): void {
    const fc = this.formGroup.get("status");
    fc.setValue(!fc.value);
  }

但是如果您无论如何都使用反应式样式表单,那么您实际上并不需要 toggleStatus 方法。用户单击将自动更改表单控件的值。 See this stackblitz(打开控制台并点击按钮或滑动开关)。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。