在api

时间:2019-09-19 03:26:58

标签: javascript angular typescript angular8

在角度8上有一个形式

my-form.component.html

<div class="container">
<form novalidate [formGroup]="registrationForm">
    <div class="form-group">
        <label for="firstName">Имя:</label>
        <input #spy required pattern=[A-Za-zА-Яа-яЁё]{2,} name="firstName" id="firstName" type="text" class="form-control" formControlName="firstName">
    </div>
    <div class="form-group">
        <label for="lastName">Фамилия:</label>
        <input #spy required pattern=[A-Za-zА-Яа-яЁё]{2,} name="lastName" id="lastName" type="text" class="form-control" formControlName="lastName">
    </div>
    <div class="form-group">
        <label for="email">E-mail:</label>
        <input #spy required email name="email" id="email" type="email" class="form-control" formControlName="email">
    </div>
    <!--{{ spy.className }}-->
    <button type="submit" class="btn btn-succes" (click)="submit(myForm)">Отправить</button>
</form>

用户写入数据时,提交按钮应使用POST方法将数据发送到API。 如果您需要任何代码,请发表评论

ts代码:

import { FormGroup, FormControl } from '@angular/forms';
import {HttpClient} from '@angular/common/http';

@Component({
  selector: 'app-my-form',
  templateUrl: './my-form.component.html',
  styleUrls: ['./my-form.component.css']
})
export class MyFormComponent implements OnInit {

  registrationForm: FormGroup;

  constructor() { }

  ngOnInit() {
    this.registrationForm = new FormGroup({
      firstName: new FormControl(),
      lastName: new FormControl(),
      email: new FormControl()
    });
  }

}```

2 个答案:

答案 0 :(得分:1)

我为您提供了一个简单的示例。...

reference

----html----

<header class="masthead">
   <div class="container h-100">
       <div class="row h-100 align-items-center justify-content-center">
           <div class="col-6">
               <div class="text-center">
                   <hello name="{{ name }}"></hello>
                    <hr>
            </div>
            <form #send="ngForm" (ngSubmit)="sendFRMData(send.value)">
                <div class="form-group">
                    <label for="title" class="text-muted">Title</label>
                <input type="text" class="form-control" id="title" 
name="titlefrm" ngModel #title='ngModel' required>
      <span class="help-block text-danger" *ngIf="!title.valid && 
title.touched">Please give Title!!</span>
      </div>
      <div class="form-group">
                    <label for="body" class="text-muted">Body</label>
<input type="text" class="form-control" id="body" name="bodyfrm" ngModel 
#body='ngModel' required>
<span class="help-block text-danger" *ngIf="!body.valid && 
body.touched">Please 
give Body!!</span>
      </div>
      <div class="form-group">
                    <label for="userId" class="text-muted">UserID</label>
<input type="text" class="form-control" id="userId" name="userIdfrm" ngModel 
#userid='ngModel' required>
<span class="help-block text-danger" *ngIf="!userid.valid && 
userid.touched">Please give UserID!!</span>
      </div>
      <div class="row">
        <div class="col-sm-6">
          <input class="form-control btn btn-success" type="submit" 
[disabled]='!send.valid'>
        </div>
        <div class="col-sm-6">
          <input class="form-control btn btn-info" type="button" value="EDIT" 
(click) = 'onEdit()'>
        </div>
      </div>
</form>
        </div>
</div>
</div>
</header>

----ts----
import { NgForm } from '@angular/forms';
@ViewChild('send') send: NgForm;
constructor(private sendData: HttpService) {
  }
sendFRMData(data: any) {
const payload = {
  title: data.titlefrm,
  body: data.bodyfrm,
  userId: data.userIdfrm
}
this.sendData.try(payload).subscribe(
  (data: any) => {
    this.respondedData = JSON.stringify(data);
    this.alert = true;
  }
);
}

----service----

try(data){ 
return 
this.http.post('https://jsonplaceholder.typicode.com/posts',data,{
headers: {
    "Content-type": "application/json; charset=UTF-8"
       }
   });
}

希望您得到答案...

答案 1 :(得分:0)

似乎您无法在Submit函数中获取表单值。 将点击事件从(click)="submit(myForm)"更改为(click)="submit(myForm.value)",然后在您的Submit函数中,您可以调用post方法

submit(formValueObject) {
    console.log(formValueObject);
    this.httpService.post(url, formValueObject).subscribe((res:any)=> {
      //your response
    })
  }

我希望对您有帮助