- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我为自己设定了登录任务,获取现有用户详细信息,然后为用户提供编辑它们的能力。我有一个像这样的 Angular 7 react 形式:
userdetails.page.ts
constructor(private formBuilder: FormBuilder,
private currentuser: UserService,
private router: Router ) {
}
ngOnInit() {
// first we need to make sure the current user data is up to date.
this.currentuser.getUserServer();
//
console.log('currentUser = ' + this.currentuser.data);
this.userDetailsForm = this.formBuilder.group({
id: [this.currentuser.data.Id],
email: [this.currentuser.data.Email], // [Validators.required, Validators.email]],
username: [this.currentuser.data.UserName],
dateofbirth: [this.currentuser.data.DateOfBirth],
title: [this.currentuser.data.Title],
firstname: [this.currentuser.data.FirstName],
middlename: [this.currentuser.data.MiddleName],
lastname: [this.currentuser.data.LastName],
displayname: [this.currentuser.data.DisplayName],
fullname: [this.currentuser.data.FullName],
detailscomplete: [this.currentuser.data.Id],
password: [this.currentuser.data.Password], // [Validators.required, Validators.minLength(6)]]
});
}
我试图将事物分开,所以有一个用户服务和一个 API 服务。 (但我不确定 API 服务是否绝对必要 - 或者它是否应该只是用户服务调用的一部分?)API 服务(正在使用的功能)是:
api.服务.ts
Get(endpoint: string) {
const fullurl = this.ServerUrl + endpoint;
return this.http.get(fullurl, {
headers: {'Content-Type': 'application/json'}
});
}
据我所知,它会返回一个可观察对象,而正是在这里我有点卡住了。来自服务器的 JSON 对象还包含一些不相关的对象以及我需要的对象,因此我尝试只获取我想要的项目。中间函数是这样的:
用户服务.ts
public data: UserData;
getUserServer() {
this.api.Get(this.api.GetUserDetailsEndPoint).subscribe(res => {
console.log('Id from server = ' + res['Id']);
this.data = {
Id: res['Id'],
Email: res['Email'],
UserName: res['UserName'],
DateOfBirth: res['DateOfBirth'],
Title: res['title'],
FirstName: res['FirstName'],
MiddleName: res['MddleName'],
LastName: res['LastName'],
DisplayName: res['DisplayName'],
FullName: res['FullName'],
DetailsComplete: res['DetailsComplete'],
Password: res['Password']
};
console.log('This Data.Id = ' + this.data.Id)
});
}
这适用于获取数据和 Id 的日志记录提供正确的信息,其他信息也在那里。 (上面最后一行。)但是,我觉得我需要制作 this.data
本身变成一个可观察的,以便返回到我可能应该订阅它的表单。
我尝试将其定义为 observable<UserData>
还有observable<IUserData>
(这是一个接口(interface)而不是一个类),但这样做会破坏元素的分配。我觉得我很接近,但缺少一些基本的东西。
这是正确的做法吗?如何将返回的数据实际放入表单中?然后我想将它放回服务器将遵循类似的思路。
最佳答案
你的代码不工作的原因是因为它是异步的。数据不会记录,因为日志是在数据到达之前执行的。
我建议先创建一个空表单,确保属性与数据中的属性完全匹配。你的做法是正确的。在您的 user.service.ts 中将代码切换为
getUserServer(): Observable<UserData> {
return this.http.get<UserData>(`pathToEndpoint`);
}
在您的userdetails.page.ts
constructor(private userService: UserService, ...) {}
ngOnInit() {
this.userForm = this.formBuilder.group({
Id: [],
...
});
this.userService.getUserServer().subscribe(user => this.userForm.patchValue(user.data));
}
表单提供的 patchValue 函数会修补您的数据和表单之间的所有键匹配项。它会忽略表单中不可用的属性,反之亦然。您应该考虑将所有属性重命名为 lowerCamelCase。
继续使用 RxJS 时的一个提示:如果您订阅了 observable,您几乎会在所有需要取消订阅的地方看到它们。但这只是事实的一半。如果您确定 observable 将要完成,那么您不必取消订阅。 HttpClient
.get 旨在在发出第一个值后完成,或抛出错误。因此,您不必取消订阅。但是在使用订阅时要注意。如果你阅读像 take 这样的运算符,你会更清楚地理解。 .
关于angular - 在 Angular 7 中将数据恢复为 react 形式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55549870/
有什么方法可以恢复删除的元素吗? 这是我删除元素的代码 myFunction() { var width = window.innerWidth; var February = doc
我有一个 TokuDB 表,由于某种原因缺少 ***_status.tokudb 文件。 我还不确定文件是否由于 TokuDB 崩溃而丢失。 问题是: 有没有办法从主要文件和关键文件(我可以从 tok
我正在 Windows 7 (x86) 上运行带有 Workbench 6.3.8 的 32 位 MySQL Server 5.7.22 本地实例(必须选择 32 位版本 - 所以,较旧的版本)。 我
1、备份 <% SQL="backup database 数据库名 to disk='"&Serve
1、ASP中怎么实现SQL数据库备份、恢复! 答:asp在线备份sql server数据库: 1、备份 <% SQL="ba
我在 R 中使用 stats::filter 函数来理解 R 中的 ARIMA 模拟(如在函数 stats::arima.sim 中)和估计。我知道 stats::filter 将线性过滤器应用于向量
我已经浏览了示例应用程序的文档和代码,并发现 files/objectbox/objectbox/data.mdb 是存储所有数据的默认文件。 假设我的理解是正确的,我有几个问题找不到文档: 我想在我
为了恢复非续订订阅类型的 InAppPurchase,我已经实现了服务器来处理此问题。 但在购买过程中,iTunes 有时不会要求用户验证他们的卡详细信息, 在这种情况下,它会在后台发送应用程序并显示
我的问题是寻找cocos2d游戏期间暂停/恢复状态(包括所有需要保存的数据信息)的设计解决方案。 包括但不限于以下情况: 1).用户选择退出,然后弹出一个对话框供用户选择“直接退出”、“暂停”; 2)
在 Mercurial 中,我有一个旧的变更集,除了对单个文件的更改外,它都很好。我将如何恢复对该单个文件的更改? 即使只是能够在上一个变更集中查看文件的状态也会很好,然后我可以剪切和粘贴。 我的 M
我的一项职能遇到了困难。我想做的是计时器在页面加载后立即启动,并且只有一个带有启动/恢复的按钮。我无法在代码中找出需要更改功能的位置。有人可以帮助我吗?谢谢! HTML: , Javascr
我正在阅读Scrap your type classes 。这为类型类提供了替代方案。然而,我被Paul Chiusano的评论所困扰。其中讨论了恢复 do 表示法 语法。 坦白说,我无法理解 ret
当 OrientDB 因某人重新启动机器而非正常关闭时,OrientDB 最终会处于数据恢复失败的状态。对于如何从这种不正常的关闭中正常恢复有什么建议吗?我们正在寻找系统在断电期间能够自行恢复的方法。
我正在构建一个 Electron 应用程序,如果发生崩溃,它必须重新加载渲染进程窗口。 目前我可以从主进程重新启动应用程序 app.relaunch(); app.quit(); 但我无法检测到窗口崩
我有 3 个 Activity ,比如说 MainActivity、 Activity 2 和 Activity 3。 在 MainActivity 中,我有一个按钮(开始/停止),当我单击此按钮时,
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 11 年前。 Improve thi
Twilio 是否支持暂停和恢复内容播放。换句话说,我有相当长的文件将播放给调用者,并且我正在尝试找到一种方法来实现暂停和恢复功能。在播放某些内容的过程中,我希望用户能够按数字暂停,然后再次按数字从音
我已经提交了 A、B、C、D 和 E。我意识到在提交 B 中发生了一些非常糟糕的事情,所以我想回到 A,这次正确地进行之前搞砸了 B 的更改,然后重新应用 C 、 D 和 E 自动。 您可能想知道为什
我的一个文件被“标记为文本”,图标也发生了变化。实际上这是一个 PHP 文件。我尝试过使用 Help -> Find Action -> Mark As 尝试将其恢复为 PHP 突出显示,但它不起作用
我有一些 SSE 程序,可以将循环中的内存归零,当指针未对齐时,它会引发 SIGSEGV进入我的处理程序。我可以在此类处理程序中获取更多信息吗例行公事,现在我不知道它是在哪里完成的,我也可以吗以某种可
我是一名优秀的程序员,十分优秀!