- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我将 Angular 9 与 Angular Material 一起使用,并且通过实现 ControlValueAccessor 接口(interface)来自定义控件。一切正常。
当表单无效时,在我的所有提交按钮中,我调用 formGroup.markAllAsTouched 因为所有 Angular Material 字段都变为红色。通过这种方式,用户可以更好地了解哪些控件无效。
我需要用我的自定义控件实现相同的行为。怎么做?
为了更好地了解情况,我创建了一个 stackblitz 项目 here
最佳答案
有no built-in functionality用于传播touched
状态到自定义控件的内部 FormControl。
您的简单选择是检查 ngDoCheck
中的状态并且一旦自定义控件被触及,内部 FormControl
的更新状态:
ngDoCheck() {
if (this.formControl.touched) {
return;
}
if (this.controlDir.control.touched) {
this.formControl.markAsTouched();
}
}
ControlValueAccessor
的这种实现。 .
viewProviders
来完成与
ControlValueAccessor
您的自定义控件的提供程序:
@Component({
selector: 'my-custom-control',
template: `
<mat-form-field id="userType">
<mat-label>My Custom Component</mat-label>
<mat-select [formControlName]="controlName" (blur)="onTouched()">
<mat-option *ngFor="let current of userTypes" [value]="current.id">{{current.name}}</mat-option>
</mat-select>
</mat-form-field>
`,
viewProviders: [{
provide: ControlContainer,
useFactory: (container: ControlContainer) => container,
deps: [[new SkipSelf(), ControlContainer]],
}]
})
export class MyCustomControl {
@Input() controlName: string;
userTypes: LookupModel[] = [
new LookupModel(1, 'first'),
new LookupModel(2, 'second')
];
}
<form [formGroup]="form">
<my-custom-control controlName="userTypeCustomControl"></my-custom-control>
关于Angular ControlValueAccessor 和 markAsTouched,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/61566769/
我已经使用日期、月份和年份的三个下拉菜单实现了一个日期选择器。日期选择器是一个实现了 ControlValueAccessor 并且运行良好的组件。但是,我希望当三个下拉菜单中的任何一个被触摸时,控件
我有这个组件使用 ControlValueAccessor .该组件有自己的内部表单,我找不到在哪里设置表单控件的初始值。 有人可以指出我正确的方向吗? import { Component, C
这是 stackblitz重现的组件/问题。 我构建了一个自定义输入组件: 获取用户对象数组以进行预输入过滤 将您的选择显示为标签 表单控件值是所选用户的数组 users[] 问题是 adding a
为什么当我使用 ControlValueAccessor 时,值不更新并以 react 形式反射(reflect)? 在我的应用程序中,我有一个表单: profileForm = new FormG
我将 Angular 9 与 Angular Material 一起使用,并且通过实现 ControlValueAccessor 接口(interface)来自定义控件。一切正常。 当表单无效时,在我
如果我在我的模板中放置一个实现 ControlValueAccessor 接口(interface)的自定义输入并像这样绑定(bind)到它的更改事件: 我的自定义输入不会在模糊时触发任何事件(
如果我在我的模板中放置一个实现 ControlValueAccessor 接口(interface)的自定义输入并像这样绑定(bind)到它的更改事件: 我的自定义输入不会在模糊时触发任何事件(
我有一个为模板驱动表单构建动态输入组件的指令。默认值由输入组件本身设置。 问题是设置默认值会导致表单被标记为脏。 如何在指令内部设置默认值而不将表单标记为脏? @Directive({ selec
我有这个自定义控件,其中包括一个选择组件。但在我的 react 形式中,值(value)永远不会传播。 有人可以帮我吗? 我的自定义控件: const SOME_SELECT_VALUE_ACCESS
我需要开发一个可重用的列表组件,它返回一个对象列表,一个简单的对象列表,那些应该被分配给 formGroup 对象值中的键。 有没有办法在 Angular 中做一个列表的自定义控件? 这是我尝试过的和
我已经实现了 ControlValueAccessor,如我正在关注的教程中所示。但是,我在其中实现 controlvalueaccessor 的组件似乎没有检测到对 ngModel 的任何更改。我错
我已经创建了一个简单的自定义 input我的 Angular 应用程序中的组件使用 ControlValueAccessor .所以,当我想创建一个表单 input元素,我不必调用 , 只能调用 .
ControlValueAccessors 在过去几个月突然出现在我面前,我对为什么或何时应该使用它们而不是使用 @Input 感到有些困惑。用我的 react 形式。 这是迄今为止我如何使用响应式(
Angular 版本:6.1 我正在尝试使用 Kara Erickson 所称的 Composite ControlValueAccessor 来实现自定义控件,如演示文稿中所示 Angular Fo
我想通过实现 ControlValueAccessor 创建自定义表单元素地址。 我正在尝试创建一个 AddressComponent,其中有多个输入字段。我想在如下所示的 react 形式中使用此组
我想通过实现 ControlValueAccessor 创建自定义表单元素地址。 我正在尝试创建一个 AddressComponent,其中有多个输入字段。我想在如下所示的 react 形式中使用此组
如我所描述in this answer ,我创建了一个自定义 ControlValueAccessor 指令来控制何时触发我的组件的 onChange 事件,并且一切正常,除了当我测试它时, regi
按比例缩小 plunkr:https://plnkr.co/edit/gGCiYjcq70xaewn3n22F?p=preview @Input() model: any; propagateChan
如果自定义组件是另一个组件下的包装器,我不确定如何使用它。 喜欢: ComponentA_withForm | --ComponentA1_withWrapperOfCustomInput |
当您在 ControlValueAccessor 中“写入值”时,为什么 ngOnChanges 没有被触发?我正在通过 registerOnChange 发出一些事件,但我在 ngOnChanges
我是一名优秀的程序员,十分优秀!