- vừa được xem lúc

cách xác thực đầu vào của một form trong Angular

0 0 6

Người đăng: thuan

Theo Viblo Asia

Thêm form và các trường vào template của component: html Copy code

<form (ngSubmit)="onSubmit()" #registerForm="ngForm">
<label for="name">Tên:</label> <input type="text" id="name" name="name" required [(ngModel)]="name">
<label for="email">Email:</label> <input type="email" id="email" name="email" required [(ngModel)]="email" #emailInput="ngModel"> <div *ngIf="emailInput.invalid && emailInput.touched" class="error-message"> Email không hợp lệ.
</div> <button type="submit" [disabled]="registerForm.invalid">Đăng ký</button> </form> Trong component, thêm mã kiểm tra xác thực vào: typescript Copy code import { Component } from '@angular/core';

@Component({ selector: 'app-registration', templateUrl: './registration.component.html', styleUrls: ['./registration.component.css'] }) export class RegistrationComponent { name: string; email: string;

onSubmit() { // Xử lý logic khi người dùng submit form } } Trong ví dụ trên, chúng ta đã sử dụng các thuộc tính required và type="email" trong các trường input để xác thực. Các thuộc tính này đảm bảo rằng người dùng phải điền đầy đủ thông tin và email phải có định dạng hợp lệ. Chúng ta sử dụng cú pháp [(ngModel)] để liên kết dữ liệu nhập vào với các thuộc tính name và email trong component.

Thêm vào đó, chúng ta sử dụng #emailInput="ngModel" để tạo một tham chiếu đến trường input email, cho phép chúng ta kiểm tra xem trường đó đã hợp lệ (invalid) và đã được chạm vào (touched) hay chưa. Nếu trường email không hợp lệ và đã được chạm vào, chúng ta hiển thị một thông

User cho toi vidu ve fetch api bang tieng viet ChatGPT Dưới đây là một ví dụ về cách sử dụng Fetch API để thực hiện các yêu cầu HTTP và truy xuất dữ liệu từ API bằng Tiếng Việt:

javascript Copy code // Gửi yêu cầu GET đến một API và lấy dữ liệu về fetch('https://api.example.com/data') .then(response => response.json()) .then(data => { // Xử lý dữ liệu trả về từ API console.log(data); }) .catch(error => { // Xử lý lỗi nếu có console.error('Đã xảy ra lỗi:', error); });

// Gửi yêu cầu POST với dữ liệu từ một form đến một API const formData = new FormData(); formData.append('name', 'John Doe'); formData.append('email', 'john@example.com');

fetch('https://api.example.com/register', { method: 'POST', body: formData }) .then(response => response.json()) .then(data => { // Xử lý dữ liệu trả về từ API console.log(data); }) .catch(error => { // Xử lý lỗi nếu có console.error('Đã xảy ra lỗi:', error); }); Trong ví dụ trên, chúng ta sử dụng phương thức fetch để gửi yêu cầu HTTP đến API. Đối với yêu cầu GET, chúng ta chỉ cần truyền URL của API vào hàm fetch. Sau đó, chúng ta sử dụng .then() để xử lý phản hồi từ API. Trong ví dụ này, chúng ta chuyển đổi phản hồi thành định dạng JSON bằng cách sử dụng .json() và sau đó xử lý dữ liệu trả về trong hàm .then() tiếp theo.

Đối với yêu cầu POST, chúng ta truyền URL của API và cấu hình cho yêu cầu POST trong tham số thứ hai của hàm fetch. Trong ví dụ này, chúng ta sử dụng FormData để tạo một đối tượng chứa dữ liệu từ form, sau đó chúng ta truyền đối tượng FormData vào phần thân (body) của yêu cầu POST. Tương tự như yêu cầu GET, chúng ta xử lý phản hồi từ API trong hàm .then().

Vui lòng thay đổi URL của API và cấu hình yêu cầu theo nhu cầu của bạn trong ví dụ trên.

User giai thich them cho toi va co giao dien render ChatGPT Tôi xin giải thích thêm về ví dụ và cung cấp cho bạn một giao diện đơn giản để hiển thị dữ liệu lấy từ API bằng Angular.

Trong ví dụ trước, chúng ta đã sử dụng Fetch API để gửi yêu cầu HTTP đến một API và xử lý dữ liệu trả về. Dưới đây là một ví dụ về cách bạn có thể kết hợp ví dụ đó với Angular và hiển thị dữ liệu trên giao diện:

Tạo một component trong Angular bằng cách chạy lệnh sau trong terminal: shell Copy code ng generate component DataComponent Trong file data.component.ts, thêm mã lấy dữ liệu từ API: typescript Copy code import { Component, OnInit } from '@angular/core';

@Component({ selector: 'app-data', templateUrl: './data.component.html', styleUrls: ['./data.component.css'] }) export class DataComponent implements OnInit { data: any;

ngOnInit() { fetch('https://api.example.com/data') .then(response => response.json()) .then(data => { this.data = data; }) .catch(error => { console.error('Đã xảy ra lỗi:', error); }); } } Trong file data.component.html, thêm mã HTML để hiển thị dữ liệu: html Copy code

Dữ liệu từ API:

<ul> <li *ngFor="let item of data">{{ item }}</li> </ul>
Trong ví dụ trên, chúng ta đã tạo một component DataComponent và sử dụng phương thức ngOnInit để gửi yêu cầu HTTP đến API và lưu trữ dữ liệu trả về trong thuộc tính data của component. Sau đó, chúng ta sử dụng ng-directive *ngIf để kiểm tra xem có dữ liệu hay không trước khi hiển thị nó trên giao diện. Nếu có dữ liệu, chúng ta sử dụng ng-directive *ngFor để lặp qua từng phần tử trong mảng data và hiển thị chúng trong danh sách (<ul>).

Để sử dụng component DataComponent, bạn có thể thêm nó vào template của component cha bằng cách sử dụng thẻ <app-data></app-data>. Ví dụ:

html Copy code

Ứng dụng Angular

<app-data></app-data> Khi bạn chạy ứng dụng Angular, component DataComponent sẽ được khởi tạo và gửi yêu cầu đến API để lấy dữ liệu. Sau đó, dữ liệu sẽ được hiển thị trên giao diện trong danh sách.

Vui lòng thay đổi URL của API và cấu hình yêu cầu tương ứng với nhu cầu của bạn trong mã l

Bình luận