首页 > 解决方案 > 更新模型包含 @DBRef [Spring-boot Angular]

问题描述

在 Spring Boot 项目中,我正在使用 Spring Data MongoDB,并且我有包含 @DBRef 的 classA 我不知道如何在前端更新它我尝试更新它所有其他变量都更新除了 classB whrreas 用于后端它的工作. 现在我希望有人让我知道如何更新 Adresse。

public class User
{
@Id
private String id;

private String email

@DBRef
private Adresse adresse;

用户控制器

@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.// -->

标签: angularspringmongodbspring-bootspring-data

解决方案


形式:UserInfo = {地址{}};


推荐阅读