{"id":1401,"date":"2023-09-01T05:00:00","date_gmt":"2023-09-01T12:00:00","guid":{"rendered":"https:\/\/www.angulartraining.com\/daily-newsletter\/?p=1401"},"modified":"2023-08-30T11:05:36","modified_gmt":"2023-08-30T18:05:36","slug":"asynchronous-form-validation-with-angular","status":"publish","type":"post","link":"http:\/\/www.angulartraining.com\/daily-newsletter\/asynchronous-form-validation-with-angular\/","title":{"rendered":"Asynchronous form validation with Angular"},"content":{"rendered":"\n<p>We&#8217;ve already covered how to write <a href=\"https:\/\/www.angulartraining.com\/daily-newsletter\/custom-form-validation-functions\/\" target=\"_blank\" rel=\"noopener\" title=\"\">custom form data validators with Angular<\/a>. We also covered how to <a href=\"https:\/\/www.angulartraining.com\/daily-newsletter\/implementing-custom-feedback-to-form-validation-with-angular\/\" target=\"_blank\" rel=\"noopener\" title=\"\">display custom validation feedback<\/a> to the user. Today, let&#8217;s take a look at how to perform asynchronous validation of our form data, which is useful when we need to make an HTTP request to a server to validate user input.<\/p>\n\n\n\n<p>The approach for asynchronous validation is very similar to what we do with regular validation. The only difference is that instead of returning <code>ValidationErrors<\/code>, we return an <code>Observable<\/code> or a <code>Promise<\/code> of such <code>ValidationErrors<\/code>:<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"197\" src=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/08\/image-41-1024x197.png\" alt=\"\" class=\"wp-image-1403\" srcset=\"http:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/08\/image-41-1024x197.png 1024w, http:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/08\/image-41-300x58.png 300w, http:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/08\/image-41-768x148.png 768w, http:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/08\/image-41-1536x296.png 1536w, http:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/08\/image-41.png 1714w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/figure>\n\n\n\n<p><\/p>\n\n\n\n<p>A <code><a href=\"https:\/\/angular.io\/api\/forms\/ValidationErrors\" target=\"_blank\" rel=\"noopener\" title=\"\">ValidationErrors<\/a><\/code> object is any keys and values you want to return. I like using keys that are the name of the form input throwing the error and the value being the error message I want to display on the screen. For instance, this is one of my typical <code>ValidationErrors<\/code> objects: <\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><img loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"133\" src=\"https:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/08\/image-42-1024x133.png\" alt=\"\" class=\"wp-image-1404\" srcset=\"http:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/08\/image-42-1024x133.png 1024w, http:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/08\/image-42-300x39.png 300w, http:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/08\/image-42-768x99.png 768w, http:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/08\/image-42-1536x199.png 1536w, http:\/\/www.angulartraining.com\/daily-newsletter\/wp-content\/uploads\/2023\/08\/image-42.png 1714w\" sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/figure>\n\n\n\n<p><\/p>\n\n\n\n<p>If you want to dig deeper, here is a link to a <a href=\"https:\/\/blog.angulartraining.com\/how-to-write-async-form-validators-with-angular-df99d016066c\" target=\"_blank\" rel=\"noopener\" title=\"\">tutorial showcasing an example of an async validator<\/a>. It&#8217;s also worth noting that asynchronous validators introduce a new validation state besides VALID and INVALID, which is PENDING. You can use that validation state to display a spinner or temporarily disable a form input while the asynchronous validation occurs.<\/p>\n","protected":false},"excerpt":{"rendered":"<p>We&#8217;ve already covered how to write custom form data validators with Angular. We also covered how to display custom validation feedback to the user. Today, let&#8217;s take a look at how to perform asynchronous validation of our form data, which is useful when we need to make an HTTP request to a server to validate [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[4,22],"tags":[],"class_list":["post-1401","post","type-post","status-publish","format-standard","hentry","category-angular","category-forms"],"aioseo_notices":[],"_links":{"self":[{"href":"http:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/posts\/1401","targetHints":{"allow":["GET"]}}],"collection":[{"href":"http:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"http:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"http:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"http:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/comments?post=1401"}],"version-history":[{"count":2,"href":"http:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/posts\/1401\/revisions"}],"predecessor-version":[{"id":1405,"href":"http:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/posts\/1401\/revisions\/1405"}],"wp:attachment":[{"href":"http:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/media?parent=1401"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"http:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/categories?post=1401"},{"taxonomy":"post_tag","embeddable":true,"href":"http:\/\/www.angulartraining.com\/daily-newsletter\/wp-json\/wp\/v2\/tags?post=1401"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}