- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我是 Angular 的新手,不知道如何使用异步调用来更新响应式表单。
我有一个基于对象模型的 react 形式。表单中的任何更改都会触发 HTTP 请求,该请求可能会发回对象的更新版本作为响应。我需要相应地更新表格。
我用 BehaviorSubject 实现了类似的东西(那些对象的列表),但不确定如何用表单来实现。
编辑:很抱歉没有包含代码。比较乱,这里总结一下。
这是我现在拥有的:
export class EditQuestionnaire implements OnInit {
questionnaireForm: FormGroup;
questionnaire: Observable<Questionnaire>;
// constructor with its dependencies omitted
ngOnInit() {
this.questionnaireForm = this.fb.group({
'id': [''],
'submitted': [false],
'questions': this.fb.array(
[]
),
});
this.questionnaire = this.questionnaireService.getQuestionnaireGeneral(); // This is an observable of a BehaviorSubject that gets updated in a service with every call to getQuestionnaire
this.questionnaireService
.getQuestionnaire(this.questionnaire.id)
.subscribe(questionnaire => {
this.questionnaireForm = this.loadQuestionnaire(questionnaire); // loads the questionnaire into the form
});
}
...
}
我还有一个子组件,表示问卷中的一个问题。在这里我检测到变化:
export class QuestionComponent implements OnInit {
@Input() questionForm: FormGroup;
@Input() questionnaireId: string;
// constructor and dependencies omitted
get text() {
return this.questionForm.get('text') as FormControl;
}
get answers() {
return this.questionForm.get('answers') as FormArray;
}
get id() {
return this.questionForm.get('id') as FormControl;
}
get comment() {
return this.questionForm.get('comment') as FormControl;
}
ngOnInit() {
const questionId = this.id.value;
this.comment.valueChanges
.pipe(
debounce(() => interval(2000))
)
.subscribe(newValue => {
this.saveComment(questionId, newValue);
});
for (const answer of this.answers.controls) {
this.answers.valueChanges.subscribe(val => {
const answerId = answer.get('id').value;
this.saveAnswer(questionId, answer);
});
}
saveComment(questionId: string, comment: string) {
this.questionnaireService.updateComment(questionnaireId, questionId, comment).subscribe(); // no need to rebuild here
}
saveAnswer(questionId: string, answerId: string) {
this.questionnaireService.updateAnswer(questionnaireId, questionId, answerId).subscribe(questionnaire => { /* trigger the form to rebuild */ })
}
}
某些问题的回答可能会触发后续问题,因此从后端发回一个全新的问卷。我在这里遇到的问题是 valueChanges 监听器将新问卷识别为更改,我的应用程序陷入了 HTTP 请求的无限循环。
关于如何解决这个问题有什么想法吗?
更新:
我最终使用 EventEmitter 将收到的问卷对象传递给父组件,我在父组件中重建了表单。
最佳答案
我假设您通过组件触发来自服务的请求。要从您的组件更新响应式(Reactive)表单对象,您可以直接分配它。例如,如果你像这样声明你的 react 形式:
this.form = new FormGroup({
name: new FormControl()
})
您可以像这样简单地更新名称:
let name = "Kyle";
this.form.controls.name.value = name;
在此处的 Angular 文档中找到:
关于Angular2 响应式表单和 BehaviorSubject,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51881982/
我有一个 rxjs@6 BehaviorSubject source$ ,我想从 source$ 获取子值 const source$ = new BehaviorSubject(someValu
场景我有一个 Territories 列表,我想从服务器获取每个 Territory 中的所有 Items。因此,我决定使用 BehaviorSubject 来尝试一下。我不知道我是不是“疯了”。这就
至少在移动应用程序中,BehaviorSubject 被频繁使用,为属性建模——它有一个当前值,可以随时查询并观察。 有时它只想转换 BehaviorSubject 而无需订阅它。例如。如果有类,它充
我在使用 Angular 服务时遇到了一个由 BehaviorSubject 引起的错误。 错误 Module '"ng5/node_modules/rxjs/BehaviorSubject"' ha
我正在使用 Angular 2 和 RxJS 5。 这两者有什么区别吗: 应该首先使用哪个?谢谢 isOpen$ = new BehaviorSubject(true); 和 isOpen$ = Be
我正在查看可观察对象的接口(interface),发现您可以将实现 PartialObserver 的任何内容传递给订阅函数。所以我用 BehaviorSubject 做到了。 像这样(一) sour
我的其中一个组件中有这个: public booleanSubject: BehaviorSubject = new BehaviorSubject(false); 当我添加 "strictFunct
您好,我有一个具有简单类型 int 的 BehaviorSubject,我将值 5 添加到它,然后添加另一个值 5。流监听器向我发送了两个事件。如果值等于最后一个值,如何强制检查值并且不发送事件。示例
在我们的单页应用程序中,我们开发了一个集中式存储类,该类使用 RxJS 行为主体来处理应用程序的状态及其所有变化。我们应用程序中的几个组件正在订阅我们商店的行为主题,以便接收对当前应用程序状态的任何更
我有一个 Angular 服务,它有一个名为 must_checkout 的 bool 属性。我的服务还包含一个名为 observable_must_checkout 的属性,它是一个调查 must_
我有一个 BehaviorSubject我希望能够filter ,但要保持新订阅者在订阅时始终获得一个值的行为主题式质量,即使最后发出的值被过滤掉。有没有一种简洁的方法可以使用 rxjs 的内置函数来
我有一个 BehaviorSubject我想重置 - 我的意思是我希望最新的值不可用,就像它刚刚创建一样。 我似乎没有看到可以执行此操作的 API,但我想还有另一种方法可以实现相同的结果吗? 我想要的
我使用 RxJS 中的 BehaviourSubject: private rights = new BehaviorSubject>([]); updateRights(rights: Array)
我几乎已经完成了 android,但对 java 8 还是陌生的。我制作了一个 BehaviourSubject>。 我在上面放置了一个可观察对象。在 Presenter 类中,我将 Behaviou
在我的 Angular 应用程序中 我多次尝试使用 BehaviorSubject 获取值,以了解值何时更改或接收。我无法在加载组件之前获取值。 通过此链接,您可以查看返回的内容: https://d
我有一个函数应该返回一个BehaviorSubject。该主题旨在返回 Profile 的最新版本 (user)Profile 只是一个包含对三个成员的引用的 POJO: - 用户, - 该用户的 M
通缉行为: subject = BehaviorSubject.create(1); subject.subscribe(number -> print(number), error -> print
我是 RxJava 的新手,我选择使用它是因为我认为它非常适合我的用例。 我有一些 Integer 值,我想在无限的时间段内观察。每当这些值之一发生变化(即一个事件)时,我希望在另一个线程上调用它的所
我有一个 EvaluateHistoryItem[] 类型的 BehaviourSubject history$。在 uploadFile 方法中,我用逗号分割上传的 .txt 文件,然后将它们推送到
我是 Angular 的新手,不知道如何使用异步调用来更新响应式表单。 我有一个基于对象模型的 react 形式。表单中的任何更改都会触发 HTTP 请求,该请求可能会发回对象的更新版本作为响应。我需
我是一名优秀的程序员,十分优秀!