发布请求未发送到服务器

时间:2018-05-20 17:45:07

标签: angular forms angular-httpclient

我正在尝试将数据发布到我从API中提取的API。

问题是它根本不会尝试发送帖子请求。 Register.component.ts:

import { Component, OnInit } from '@angular/core';
import { RegisterService } from '../register.service';
import { FormGroup, FormBuilder, FormControl, Validators, FormArray, ReactiveFormsModule } from '@angular/forms';
import { user } from '../user'
@Component({
  selector: 'app-register',
  templateUrl: './register.component.html',
  styleUrls: ['./register.component.css']
})
export class RegisterComponent implements OnInit {
  public myForm: FormGroup;
  public submitted: boolean;
  public events: any[] = [];

  constructor(private registerService: RegisterService, 
  private _fb: FormBuilder) { }

  ngOnInit() {
    this.myForm = new FormGroup({
      username: new FormControl('', [<any>Validators.required, <any>Validators.minLength(5)]),
      email: new FormControl('', [<any>Validators.required, <any>Validators.minLength(5)]),
      org_number: new FormControl('', [<any>Validators.required, <any>Validators.minLength(5)]),
      password: new FormControl('', [<any>Validators.required, <any>Validators.minLength(8)])
    });
  }

  save(model: user, isValid: boolean){
    this.submitted = true;
    this.registerService.postUser(model)
    console.log(model, isValid)
  }

它正在呼叫的服务:

import { Injectable } from '@angular/core';
import { user } from './user';
import { Observable, of } from 'rxjs';
import { map, catchError } from 'rxjs/operators'
import { HttpClient, HttpHeaders } from '@angular/common/http';

const HttpOptions = {
  headers: new HttpHeaders({ 'Content-type': 'application/json' })
};
const HttpOption2 = {
  headers: new HttpHeaders({ 'Content-type': 'application/x-www-form-urlencoded' })
}
@Injectable({
  providedIn: 'root'
})
export class RegisterService {

  private usersUrl= 'api/v1/accounts';

  constructor(
    private http: HttpClient,

  ) { }

  getUsers(): Observable<user[]> {
    return this.http.get<user[]>(this.usersUrl)
  }
  postUser(object): Observable<user[]>{
    console.log(object)
    console.log('Did it enter this?')
    return this.http.post<user[]>(this.usersUrl, user, HttpOptions)
  }
}

我的代码输出预期信息:用户名:'用户名',电子邮件:'电子邮件'等。

我知道它会调用该函数,因为它还会输出:'它输入了吗?'。

我的API没有收到邮件请求,我不明白为什么。我一直在official angular Httpclient页面上搜索答案,以及大量的堆栈溢出帖子,我尝试添加.subscribe但我得到错误类型订阅不能分配给observable用户,如果我添加。 map()我得到的地图在类型observable用户上不存在,如果我添加.pipe()我没有收到错误消息,但仍然没有Post-request。 如果我添加.pipe(       catchError(this.handleError('addHero',hero))     ); 我得到类型observable用户不能分配给observable用户类型。有什么想法吗?

1 个答案:

答案 0 :(得分:2)

您需要订阅要调用的请求,

  this.registerService.postUser(model).subscribe(result => this.result =result);

确保声明名为result的变量以分配响应数据

result : any;