- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在我的应用程序 Angular2RC5 中,我有一个 SSN 输入,其工作是在用户输入 SSN(例如 123-34-3434)时添加破折号。我将其用作“ react 形式”的一部分(那些不是模板形式的......)。我的模板如下所示:
<form class="form-horizontal" [formGroup]="form" (ngSubmit)="submit()">
<div class="thumbnail">
<p class="lead">Please enter your <span *ngIf="context==='fr-secondary'">Spouse's </span> Last Name, SSN, Tax Year, and Quarter</p>
//other inputs
<div class="form-group">
<label class="col-sm-2" for="inputSSN">SSN</label>
<div class="col-sm-4">
<ssn-input formControlName="ssn"></ssn-input>
<!--<span class="help-block error" *ngIf="form.controls['ssn'].errors && form.controls['ssn'].errors['required']">required</span>
<span class="help-block error" *ngIf="form.controls['ssn'].errors && form.controls['ssn'].errors['patternError']">Invalid SSN</span>-->
</div>
</div>
</div>
<button type="submit" class="btn btn-primary pull-right">Next</button>
</form>
每当他们点击提交时,我们都会保存数据,然后如果他们表明他们已婚,我们想重置表格并收集他们配偶的数据。
因此,当我执行 this.form.reset()
时,除了 SSN 输入(自定义输入)之外的所有输入都会重置,表单后端的 SSN 值也会重置,但之前的值对用户仍然可见(这意味着如果他们点击提交,它将作为空字符串提交,即使他们可以看到)。
我也试过做 this.form.controls['ssn'].setValue('')
并且它做了同样的事情。更改表单上的值,但该值仍显示在页面上。
这是整个 SSN 组件:
import { Component, OnInit, forwardRef, Input } from '@angular/core';
import { FormControl, ControlValueAccessor, NG_VALUE_ACCESSOR, NG_VALIDATORS } from '@angular/forms';
export function createSSNPatternValidator() {
return (c: FormControl) => {
let pattern = /\d{9}/;
let err = {
patternError: {
pattern: /\d{3}-\d{2}-\d{4}/
}
};
return (c.value && !c.value.match(pattern) && c.value.length > 0) ? err : null;
};
}
@Component({
selector: 'ssn-input',
template: `
<input type="text" (input)="updateValue($event)" class="form-control" />
`,
providers: [
{ provide: NG_VALUE_ACCESSOR, useExisting: forwardRef(() => SSNInputComponent), multi: true },
{ provide: NG_VALIDATORS, useExisting: forwardRef(() => SSNInputComponent), multi: true }
]
})
export class SSNInputComponent implements ControlValueAccessor, OnInit {
value: string = '';
propagateChange: any = () => {};
validateFn: any = () => {};
ngOnInit() {
this.validateFn = createSSNPatternValidator();
}
writeValue(value) {
if (value) {
this.value = value;
}
}
registerOnChange(fn) {
this.propagateChange = fn;
}
registerOnTouched() {}
updateValue(event) {
let newValue = event.target.value;
newValue = newValue.replace(/\D/g, '').substr(0, 9);
this.value = newValue;
newValue =
newValue.substr(0, 3) + ((newValue.length >= 4) ? ('-' + newValue.substr(3, 2) + ((newValue.length >= 6) ? '-' + newValue.substr(5, 4) : '')) : '');
event.target.value = newValue;
this.propagateChange(this.value);
}
validate(c: FormControl) {
return this.validateFn(c);
}
}
编辑:plunkr
最佳答案
如果使用 writeValue
更新输入,则需要将值分配给输入。
这段代码
writeValue(value) {
if (value) {
this.value = value;
}
}
如果值为 null
并且您需要将输入绑定(bind)到 this.value
以便它得到更新,这将显式跳过写入。
关于Angular2 Reactive form.reset()不清除自定义组件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39146859/
类型‘AbstractControl’上不存在属性‘Controls’。
主要是我很好奇。 我们有一个名为 Unit 的对象在我们的代码库中 - 代表桥梁或道路的组件。在我们的例子中,看到带有 Unit 的 ReactiveUI 命令可能会模棱两可。作为声明中的泛型之一。
我一直听说六边形架构必须与任何框架无关,并使用接口(interface) (SPI) 来委托(delegate)不属于业务层的每个代码部分。 但是如何在不使用额外框架的情况下通过六边形架构创建一个响应
我读了 Reactive Manifesto . 但我无法理解 event driven architectures 之间的核心差异和 message driven architectures .结果
申请要求: 订阅两个事件流 A 和 B 对于每个 A 事件,一段时间后应该有相应的 B 事件 如果没有相应的 B 到达(及时),应用程序会监视 A 事件并发出警报 B 事件可以以与 A 事件不同的顺序
Closed. This question is opinion-based。它当前不接受答案。 想改善这个问题吗?更新问题,以便editing this post用事实和引用来回答。 4年前关闭。
我有一个 ViewModel,它在其初始化程序中有一个输入 init(sliderEvents: Reactive) { 在测试中我想做类似的事情 slider.send(.touchDownInsi
经典实时搜索示例: var searchResults = from input in textBoxChanged from results in GetDa
我有一个响应式(Reactive)管道来处理传入的请求。对于每个请求,我需要调用一个与业务相关的函数 ( doSomeRelevantProcessing )。 完成后,我需要将发生的事情通知一些外部
是否可以为响应式扩展实现基于硬件计时器的自定义调度程序?我该如何开始,有什么好的例子吗? 我有一个硬件可以每毫秒向我发送一个准确的中断。我想利用它来创建更精确的 RX 调度程序。 更新 感谢 Asti
我正在通过网络浏览 Rx 框架 Material ,我发现了很多。 现在,每当我为此在 google 上搜索时,我还会在 wikipedia 链接中找到“响应式(Reactive)编程”。 由于响应式
关闭。这个问题是opinion-based .它目前不接受答案。 想改进这个问题?更新问题,以便 editing this post 可以用事实和引用来回答它. 6年前关闭。 Improve this
SignalR 与响应式扩展是同一回事吗?你能解释一下为什么或为什么不吗? 最佳答案 不,它们绝对不是同一件事。 Reactive Extensions 是一个用于创建和组合可观察的数据流或事件流的库
我知道有一种简单的方法可以做到这一点 - 但今晚它打败了我...... 我想知道两个事件是否在 300 毫秒内发生,就像双击一样。 在 300 毫秒内单击两次左键鼠标 - 我知道这是构建响应式(Rea
我们的应用程序使用 Reactive Extensions (Rx)。这些通常通过 Microsoft 的可下载包安装。但是,当我们发布应用程序时,我们会提供 dll 的副本(即 System.Cor
我想了解 Reactive 和 ReactiveStreams 之间的区别,特别是在 RxJava 的上下文中? 我能想到的最多的是 Reactive Streams 在规范中有一些背压的概念,但它已
我想探索来自 Quarkus 的响应式 REST 客户端的慢速后端,并在他们建议的样本 (https://github.com/quarkusio/quarkus-quickstarts/tree/m
假设我有一个存储桶,我需要从中获取日期早于现在的文档。 该文档如下所示: { id: "1", date: "Some date", otherObjectKEY: "key1" } 对于每个文档,我
我有一个 RIA 服务数据服务,它有几个函数调用,如下所示: public InvokeOperation SomeFunc( SomeData data, Action> callb
我一直在使用 Rx 在单个应用程序中创建事件总线(想想 CQRS/ES),它似乎工作得很好。然而,在调查了一堆不同的事件溯源框架之后,我还没有看到使用过一次 Rx。与基于反射/容器的调度程序相比,它似
我是一名优秀的程序员,十分优秀!