繁体   English   中英

更新 model 包含 @DBRef [Spring-boot Angular]

[英]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.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM