[英]Updating model contains @DBRef [Spring-boot Angular]
在 spring 引导项目中,我正在使用 Spring 数据 MongoDB 并且我有包含 @DBRef 的 classA 我不知道如何在工作的前端更新它的所有后端变量. 现在我希望有人让我知道如何更新 Adresse。
public class User
{
@Id
private String id;
private String email
@DBRef
private Adresse adresse;
用户.Controller
@PatchMapping("/update/{id}")
public ResponseEntity<?> update(@Valid @RequestBody Utilisateur user, @PathVariable("id") String id){
Optional<Utilisateur> userData = utilisateurRepository.findById(id);
Utilisateur userToEdit = userData.get();
if(user.getAdresse()!=null){
Adresse addr = new Adresse(user.getAdresse().getAdresse(), user.getAdresse().getVille(), user.getAdresse().getCode_postal()
, user.getAdresse().getRegion(), user.getAdresse().getPays());
this.adresseRepository.save(addr);
userToEdit.setAdresse(addr);
用户服务
updateProfile(userData: any, id: string ): Observable<any> {
return this.http.patch( API_URL + 'update/' + id, userData, httpOptions);
}
组件.ts
form: any = {};
id: string;
errorMessage = '';
currentUser: any;
constructor(private userservice: UserService, private route: ActivatedRoute, private router: Router, private token: TokenStorageService) { }
ngOnInit() {
this.currentUser = this.token.getUser();
}
onSubmit() {
this.userservice.updateProfile(this.form, this.currentUser.id).subscribe(
data => {
console.log(data);
},
err => {
this.errorMessage = err.error.message;
}
);
}
组件.html
<div class="form-group">
<label>Address</label>
<input type="text" class="form-control" placeholder=""
name="adresse"
[(ngModel)]="form.adresse.adresse"
required
#adresse="ngModel">
</div> <!-- form-group end.// -->
<div class="form-group col-md-6">
<label>City</label>
<input type="text" class="form-control"
name="ville"
[(ngModel)]="form.adresse.ville"
required
#ville="ngModel">
</div> <!-- form-group end.// -->
形式:UserInfo = {地址{}};
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.