{"id":15822,"date":"2024-01-17T15:03:16","date_gmt":"2024-01-17T11:33:16","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/"},"modified":"2024-01-17T15:03:16","modified_gmt":"2024-01-17T11:33:16","slug":"%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/","title":{"rendered":"\u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u0641\u0631\u0645 \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a Vanilla \u0627\u0645\u0631\u0648\u0632\u0647 \u0627\u06a9\u062b\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0648\u0628 \u0627\u0632 \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u0646\u062f \u06a9\u0647 \u06cc\u06a9 \u0641\u0631\u0645 \u0631\u0627 \u067e\u0631 \u06a9\u0646\u06cc\u062f\u060c \u0686\u0647 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0628\u0627\u0646\u06a9\u06cc \u0622\u0646\u0644\u0627\u06cc\u0646 \u06cc\u0627 \u06cc\u06a9 \u0633\u0631\u0648\u06cc\u0633 \u067e\u062e\u0634 \u0645\u0648\u0633\u06cc\u0642\u06cc.  \u0648 \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0646\u0647\u0627\u06cc\u06cc \u0647\u0631\u06af\u0632 \u0642\u0627\u0628\u0644 \u0627\u0639\u062a\u0645\u0627\u062f \u0646\u06cc\u0633\u062a\u0646\u062f\u060c \u0628\u0627\u06cc\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u0641\u0631\u06cc\u0628 \u062f\u0647\u06cc\u0645 \u062a\u0627 \u062a\u0634\u062e\u06cc\u0635 \u062f\u0647\u062f \u06a9\u0647 \u0648\u0631\u0648\u062f\u06cc \u0646\u0627\u062f\u0631\u0633\u062a \u0627\u0633\u062a&#8230;"},"content":{"rendered":"<div id=\"ez-toc-container\" class=\"ez-toc-v2_0_85 counter-hierarchy ez-toc-counter ez-toc-custom ez-toc-container-direction\">\n<div class=\"ez-toc-title-container\"><p class=\"ez-toc-title\" style=\"cursor:inherit\">\u0633\u0631\u0641\u0635\u0644\u0647\u0627\u06cc \u0645\u0637\u0644\u0628<\/p>\n<\/div><nav><ul class='ez-toc-list ez-toc-list-level-1 ' ><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-1\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d9%85%d8%b9%d8%b1%d9%81%db%8c\" >\u0645\u0639\u0631\u0641\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%db%8c%da%a9_%d9%81%d8%b1%d9%85\" >\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0641\u0631\u0645<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-3\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d9%81%d8%b1%d9%85_%e2%80%93_%d8%a7%d9%84%d8%b2%d8%a7%d9%85%d8%a7%d8%aa\" >\u0641\u0631\u0645 &#8211; \u0627\u0644\u0632\u0627\u0645\u0627\u062a<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d8%a8%d8%b1%d9%be%d8%a7%db%8c%db%8c\" >\u0628\u0631\u067e\u0627\u06cc\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1_%d8%b3%d9%86%d8%ac%db%8c_%d9%87%d8%a7\" >\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0627\u0639\u062a\u0628\u0627\u0631 \u0633\u0646\u062c\u06cc \u0647\u0627<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d8%ad%d8%b1%d9%81_%d8%a7%d9%88%d9%84_%d9%86%d8%a7%d9%85_%da%a9%d8%a7%d8%b1%d8%a8%d8%b1%db%8c_%d8%a8%d8%b2%d8%b1%da%af_%d8%a7%d8%b3%d8%aa\" >\u062d\u0631\u0641 \u0627\u0648\u0644 \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0628\u0632\u0631\u06af \u0627\u0633\u062a<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d9%86%d8%a7%d9%85_%da%a9%d8%a7%d8%b1%d8%a8%d8%b1%db%8c_%d8%ad%d8%af%d8%a7%d9%82%d9%84_%d8%b4%d8%a7%d9%85%d9%84_%db%8c%da%a9_%d8%b1%d9%82%d9%85_%d8%a7%d8%b3%d8%aa\" >\u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u062d\u062f\u0627\u0642\u0644 \u0634\u0627\u0645\u0644 \u06cc\u06a9 \u0631\u0642\u0645 \u0627\u0633\u062a<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d8%b1%d9%85%d8%b2_%d8%b9%d8%a8%d9%88%d8%b1_%d8%a8%db%8c%d9%86_8_%d8%aa%d8%a7_20_%da%a9%d8%a7%d8%b1%d8%a7%da%a9%d8%aa%d8%b1_%d8%a7%d8%b3%d8%aa\" >\u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0628\u06cc\u0646 8 \u062a\u0627 20 \u06a9\u0627\u0631\u0627\u06a9\u062a\u0631 \u0627\u0633\u062a<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-9\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d8%b1%d9%85%d8%b2_%d8%b9%d8%a8%d9%88%d8%b1_%d8%ad%d8%af%d8%a7%d9%82%d9%84_%d8%b4%d8%a7%d9%85%d9%84_%db%8c%da%a9_%d9%86%d9%88%db%8c%d8%b3%d9%87_%d8%a8%d8%b2%d8%b1%da%af_%d8%a7%d8%b3%d8%aa\" >\u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u062d\u062f\u0627\u0642\u0644 \u0634\u0627\u0645\u0644 \u06cc\u06a9 \u0646\u0648\u06cc\u0633\u0647 \u0628\u0632\u0631\u06af \u0627\u0633\u062a<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-10\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d8%a8%d8%b1%d8%b1%d8%b3%db%8c_%da%a9%d9%86%db%8c%d8%af_%da%a9%d9%87_%d8%af%d9%88_%d8%b1%d9%85%d8%b2_%d8%b9%d8%a8%d9%88%d8%b1_%db%8c%da%a9%d8%b3%d8%a7%d9%86_%d9%87%d8%b3%d8%aa%d9%86%d8%af\" >\u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u062f\u0648 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u06cc\u06a9\u0633\u0627\u0646 \u0647\u0633\u062a\u0646\u062f<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-11\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d9%86%d9%85%d8%a7%db%8c%d8%b4_%d9%be%db%8c%d8%a7%d9%85_%d9%87%d8%a7%db%8c_%d8%ae%d8%b7%d8%a7\" >\u0646\u0645\u0627\u06cc\u0634 \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u062e\u0637\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-12\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d8%aa%d8%b3%d8%aa_%da%a9%d8%af\" >\u062a\u0633\u062a \u06a9\u062f<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-13\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1%d8%b3%d9%86%d8%ac%db%8c-%d9%81%d8%b1%d9%85-%d8%b3%d9%85%d8%aa-%d9%85%d8%b4%d8%aa%d8%b1%db%8c-%d8%a8%d8%a7-%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87-%d8%a7%d8%b2\/#%d9%86%d8%aa%db%8c%d8%ac%d9%87\" >\u0646\u062a\u06cc\u062c\u0647<\/a><\/li><\/ul><\/nav><\/div>\n<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 4<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<div class=\"content\"><noscript><\/p>\n<style>.lazyload-placeholder { display: none;  }<\/style>\n<p><\/noscript><\/p>\n<h2 id=\"introduction\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b9%d8%b1%d9%81%db%8c\"><\/span>\u0645\u0639\u0631\u0641\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u0645\u0631\u0648\u0632\u0647 \u0627\u06a9\u062b\u0631 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0648\u0628 \u0627\u0632 \u0634\u0645\u0627 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u0646\u062f \u06a9\u0647 \u06cc\u06a9 \u0641\u0631\u0645 \u0631\u0627 \u067e\u0631 \u06a9\u0646\u06cc\u062f\u060c \u0686\u0647 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0628\u0627\u0646\u06a9\u06cc \u0622\u0646\u0644\u0627\u06cc\u0646 \u06cc\u0627 \u06cc\u06a9 \u0633\u0631\u0648\u06cc\u0633 \u067e\u062e\u0634 \u0645\u0648\u0633\u06cc\u0642\u06cc.<\/p>\n<p>\u0648 \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0646\u0647\u0627\u06cc\u06cc \u0647\u0631\u06af\u0632 \u0642\u0627\u0628\u0644 \u0627\u0639\u062a\u0645\u0627\u062f \u0646\u06cc\u0633\u062a\u0646\u062f\u060c \u0628\u0627\u06cc\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u0627\u062d\u0645\u0642 \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0648\u0631\u0648\u062f\u06cc \u0646\u0627\u062f\u0631\u0633\u062a \u0627\u0633\u062a \u062a\u0634\u062e\u06cc\u0635 \u062f\u0647\u062f \u0648 \u0622\u0646 \u0631\u0627 \u0628\u0627 \u06cc\u06a9 \u067e\u06cc\u0627\u0645 (\u062e\u0637\u0627) \u0645\u0646\u0627\u0633\u0628 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f.<\/p>\n<p><em>\u0627\u0639\u062a\u0628\u0627\u0631 \u0633\u0646\u062c\u06cc \u0641\u0631\u0645<\/em> \u062a\u06a9\u0646\u06cc\u06a9\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0631\u0627\u06cc \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0627\u0632 \u0627\u0631\u0627\u0626\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0631\u0627 \u0628\u0631\u0622\u0648\u0631\u062f\u0647 \u0646\u0645\u06cc \u06a9\u0646\u062f \u062a\u0648\u0633\u0637 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0627\u0631\u0627\u0626\u0647 \u0634\u062f\u0647 \u062f\u0627\u0631\u0627\u06cc \u062d\u062f\u0627\u0642\u0644 \u06cc\u06a9 \u06a9\u0627\u0631\u0627\u06a9\u062a\u0631 \u0628\u0632\u0631\u06af \u0648 \u06cc\u06a9 \u0639\u062f\u062f \u0627\u0633\u062a.  \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u062a\u0623\u06cc\u06cc\u062f \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u06cc\u0627 \u0633\u0645\u062a \u0633\u0631\u0648\u06cc\u0633 \u06af\u06cc\u0631\u0646\u062f\u0647.<\/p>\n<p><em>\u0627\u0639\u062a\u0628\u0627\u0631 \u0633\u0646\u062c\u06cc \u0633\u0645\u062a \u0633\u0631\u0648\u0631<\/em> \u0627\u06cc\u062f\u0647 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u067e\u0633 \u0627\u0632 \u0627\u0631\u0633\u0627\u0644 \u0628\u0647 \u0633\u0631\u0648\u0631\u0647\u0627 \u0627\u0633\u062a.  \u0627\u06af\u0631 \u062f\u0627\u062f\u0647 \u0647\u0627 \u062f\u0631 \u0641\u0631\u0645\u062a \u0645\u0648\u0631\u062f \u0627\u0646\u062a\u0638\u0627\u0631 \u0646\u0628\u0627\u0634\u062f\u060c \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u0634\u0648\u062f.<\/p>\n<p>\u0627\u0632 \u0633\u0648\u06cc \u062f\u06cc\u06af\u0631\u060c <em>\u0627\u0639\u062a\u0628\u0627\u0631 \u0633\u0646\u062c\u06cc \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc<\/em> \u0645\u0633\u062a\u0644\u0632\u0645 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0648\u0631\u0648\u062f\u06cc \u062a\u0648\u0633\u0637 \u06a9\u0627\u0631\u0628\u0631 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0642\u0628\u0644 \u0627\u0632 \u0627\u0631\u0633\u0627\u0644 \u0628\u0647 \u0633\u0631\u0648\u0631 \u0627\u0633\u062a.  \u0627\u06cc\u0646 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u06a9\u0627\u0631\u0622\u0645\u062f\u062a\u0631 \u0627\u0632 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0627\u0633\u062a \u0632\u06cc\u0631\u0627 \u0627\u0632 \u0631\u0641\u062a \u0648 \u0628\u0631\u06af\u0634\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0647 \u0633\u0631\u0648\u0631 \u0648 \u0628\u0631\u06af\u0634\u062a \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u0645\u06cc \u06a9\u0646\u062f.  \u0627\u06cc\u0646 \u0647\u0645\u0686\u0646\u06cc\u0646 \u06cc\u06a9 \u0641\u06cc\u0644\u062a\u0631 \u0627\u0648\u0644\u06cc\u0647 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u062c\u0627\u06cc \u0628\u0631\u062e\u0648\u0631\u062f \u0628\u0627 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0646\u0627\u062f\u0631\u0633\u062a \u067e\u0633 \u0627\u0632 \u0639\u0628\u0648\u0631\u060c \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u0645\u06cc\u200c\u06a9\u0646\u062f \u06a9\u0647 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u062f\u0631\u0633\u062a \u0627\u0632 \u0622\u0646 \u0639\u0628\u0648\u0631 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f.<\/p>\n<p>\u0627\u06cc\u0646 \u0628\u062f\u0627\u0646 \u0645\u0639\u0646\u0627 \u0646\u06cc\u0633\u062a \u06a9\u0647 \u0633\u0631\u0648\u0631 \u0646\u0628\u0627\u06cc\u062f \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u062f\u0627\u062f\u0647 \u0631\u0627 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f &#8211; \u0645\u0627 \u062f\u0631 \u0627\u0628\u062a\u062f\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0628\u0631\u0631\u0633\u06cc \u0647\u0633\u062a\u06cc\u0645.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0622\u0645\u0648\u0632\u0634\u060c \u0631\u0648\u0634 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0648\u0627\u0646\u06cc\u0644\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0631\u0627 \u0645\u0648\u0631\u062f \u0628\u062d\u062b \u0642\u0631\u0627\u0631 \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u062f.<\/p>\n<h2 id=\"creatingaform\"><span class=\"ez-toc-section\" id=\"%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%db%8c%da%a9_%d9%81%d8%b1%d9%85\"><\/span>\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0641\u0631\u0645<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0641\u0631\u0645 \u062b\u0628\u062a \u0646\u0627\u0645 \u0633\u0627\u062f\u0647 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0634\u0627\u0645\u0644 \u0641\u06cc\u0644\u062f\u0647\u0627\u06cc \u0632\u06cc\u0631 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f:<\/p>\n<ol>\n<li><code>username<\/code><\/li>\n<li><code>first-password<\/code>  &#8211; \u0628\u0631\u0627\u06cc \u0628\u0631\u0631\u0633\u06cc \u0631\u0645\u0632 \u0627\u0648\u0644\u06cc\u0647 \u0628\u0631\u0627\u06cc \u0645\u0639\u06cc\u0627\u0631\u0647\u0627\u06cc \u062e\u0627\u0635 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f<\/li>\n<li><code>second-password<\/code>  &#8211; \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u062a\u0623\u06cc\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f \u0648 \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0634\u062a\u0628\u0627\u0647 \u062a\u0627\u06cc\u067e\u06cc \u062f\u0631 \u0622\u0646 \u0627\u0646\u062c\u0627\u0645 \u0646\u062f\u0627\u062f\u0647 \u0627\u0633\u062a <code>first-password<\/code> \u0631\u0634\u062a\u0647.<\/li>\n<\/ol>\n<p>&#8230; \u0648 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0645\u0627 \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u062f <code>index.html<\/code> \u0641\u0627\u06cc\u0644:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">&lt;!DOCTYPE <span class=\"hljs-meta-keyword\">html<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">html<\/span> <span class=\"hljs-attr\">lang<\/span>=<span class=\"hljs-string\">\"en\"<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">head<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">meta<\/span> <span class=\"hljs-attr\">charset<\/span>=<span class=\"hljs-string\">\"UTF-8\"<\/span> \/&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">meta<\/span> <span class=\"hljs-attr\">name<\/span>=<span class=\"hljs-string\">\"viewport\"<\/span> <span class=\"hljs-attr\">content<\/span>=<span class=\"hljs-string\">\"width=device-width, initial-scale=1.0\"<\/span> \/&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span> <span class=\"hljs-attr\">defer<\/span> <span class=\"hljs-attr\">src<\/span>=<span class=\"hljs-string\">\"validate.js\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">title<\/span>&gt;<\/span>Form Validation<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">title<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">head<\/span>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">body<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>Form Validation Using JavaScript<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">form<\/span> <span class=\"hljs-attr\">id<\/span>=<span class=\"hljs-string\">\"form\"<\/span> <span class=\"hljs-attr\">action<\/span>=<span class=\"hljs-string\">\"\/\"<\/span> <span class=\"hljs-attr\">method<\/span>=<span class=\"hljs-string\">\"GET\"<\/span>&gt;<\/span>\n      <span class=\"hljs-comment\">&lt;!-- We are only interested in client-side validation now --&gt;<\/span>\n\n      <span class=\"hljs-comment\">&lt;!-- All the fields are required --&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">label<\/span> <span class=\"hljs-attr\">for<\/span>=<span class=\"hljs-string\">\"username\"<\/span>&gt;<\/span>Username: <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">label<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">input<\/span> <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"text\"<\/span> <span class=\"hljs-attr\">name<\/span>=<span class=\"hljs-string\">\"username\"<\/span> <span class=\"hljs-attr\">id<\/span>=<span class=\"hljs-string\">\"username\"<\/span> <span class=\"hljs-attr\">autofocus<\/span> <span class=\"hljs-attr\">required<\/span> \/&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">label<\/span> <span class=\"hljs-attr\">for<\/span>=<span class=\"hljs-string\">\"first-password\"<\/span>&gt;<\/span>Password: <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">label<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">input<\/span>\n          <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"password\"<\/span>\n          <span class=\"hljs-attr\">name<\/span>=<span class=\"hljs-string\">\"firstPassword\"<\/span>\n          <span class=\"hljs-attr\">id<\/span>=<span class=\"hljs-string\">\"first-password\"<\/span>\n          <span class=\"hljs-attr\">required<\/span>\n        \/&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">label<\/span> <span class=\"hljs-attr\">for<\/span>=<span class=\"hljs-string\">\"second-password\"<\/span>&gt;<\/span>Confirm Password: <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">label<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">input<\/span>\n          <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"password\"<\/span>\n          <span class=\"hljs-attr\">name<\/span>=<span class=\"hljs-string\">\"secondPassword\"<\/span>\n          <span class=\"hljs-attr\">id<\/span>=<span class=\"hljs-string\">\"second-password\"<\/span>\n          <span class=\"hljs-attr\">required<\/span>\n        \/&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> <span class=\"hljs-attr\">type<\/span>=<span class=\"hljs-string\">\"submit\"<\/span>&gt;<\/span>Submit<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">form<\/span>&gt;<\/span>\n\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">id<\/span>=<span class=\"hljs-string\">\"show-error\"<\/span>&gt;<\/span>No validation error yet!<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-comment\">&lt;!--We will use this div to display validation error --&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">body<\/span>&gt;<\/span>\n<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">html<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 HTML \u06cc\u06a9 \u0641\u0631\u0645 \u0633\u0627\u062f\u0647 \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f \u06a9\u0647 \u0628\u0647 \u0634\u06a9\u0644 \u0632\u06cc\u0631 \u0627\u0633\u062a:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/client-side-form-validation-using-vanilla-javascript-1.jpg\" alt=\"\" title=\"\"><\/p>\n<h2 id=\"formrequirements\"><span class=\"ez-toc-section\" id=\"%d9%81%d8%b1%d9%85_%e2%80%93_%d8%a7%d9%84%d8%b2%d8%a7%d9%85%d8%a7%d8%aa\"><\/span>\u0641\u0631\u0645 &#8211; \u0627\u0644\u0632\u0627\u0645\u0627\u062a<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0642\u0628\u0644 \u0627\u0632 \u0646\u0648\u0634\u062a\u0646 \u0647\u0631 \u06a9\u062f\u06cc\u060c \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0627\u0628\u062a\u062f\u0627 \u0644\u06cc\u0633\u062a \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u0647\u0627\u06cc\u06cc \u0631\u0627 \u06a9\u0647 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u0645 \u0645\u0631\u0648\u0631 \u06a9\u0646\u06cc\u0645:<\/p>\n<ul>\n<li>\u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u062d\u0627\u0635\u0644 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0628\u0627 \u06cc\u06a9 \u062d\u0631\u0641 \u0628\u0632\u0631\u06af \u0634\u0631\u0648\u0639 \u0645\u06cc \u0634\u0648\u062f<\/li>\n<li>\u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0628\u0627\u06cc\u062f \u062d\u062f\u0627\u0642\u0644 \u062f\u0627\u0631\u0627\u06cc \u06cc\u06a9 \u0631\u0642\u0645 \u0628\u0627\u0634\u062f<\/li>\n<li>\u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0637\u0648\u0644 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0628\u06cc\u0646 8 \u062a\u0627 20 \u06a9\u0627\u0631\u0627\u06a9\u062a\u0631 \u0628\u0627\u0634\u062f<\/li>\n<li>\u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u062d\u062f\u0627\u0642\u0644 \u06cc\u06a9 \u062d\u0631\u0641 \u0628\u0632\u0631\u06af \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f<\/li>\n<li>\u0645\u0637\u0627\u0628\u0642\u062a \u062f\u0648 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0631\u0627 \u062a\u0623\u06cc\u06cc\u062f \u06a9\u0646\u06cc\u062f<\/li>\n<\/ul>\n<p>\u062f\u0631 \u0635\u0648\u0631\u062a\u06cc \u06a9\u0647 \u0648\u0631\u0648\u062f\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0628\u0627 \u0627\u0644\u0632\u0627\u0645\u0627\u062a \u0628\u0627\u0644\u0627 \u0645\u0637\u0627\u0628\u0642\u062a \u0646\u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645:<\/p>\n<ul>\n<li>\u0645\u062a\u0646 \u0622\u062e\u0631\u06cc\u0646 <code>div<\/code> \u0639\u0648\u0636 \u0634\u062f\u0646<\/li>\n<li>\u0627\u0632 \u0627\u0631\u0633\u0627\u0644 \u0641\u0631\u0645 \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u06a9\u0646\u06cc\u062f<\/li>\n<\/ul>\n<h2 id=\"setup\"><span class=\"ez-toc-section\" id=\"%d8%a8%d8%b1%d9%be%d8%a7%db%8c%db%8c\"><\/span>\u0628\u0631\u067e\u0627\u06cc\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u0628\u062a\u062f\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u0633\u0627\u0632\u06cc\u0645 <code>validate.js<\/code> \u0648 \u0622\u0646 \u0631\u0627 \u0628\u0627 \u0645\u0627 \u067e\u06cc\u0648\u0646\u062f \u062f\u0647\u06cc\u062f <code>index.html<\/code> \u0641\u0627\u06cc\u0644 \u062f\u0627\u062e\u0644 \u0645\u0627 <code>head<\/code> \u0628\u0631\u0686\u0633\u0628:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">script<\/span> <span class=\"hljs-attr\">defer<\/span> <span class=\"hljs-attr\">src<\/span>=<span class=\"hljs-string\">\"validate.js\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">script<\/span>&gt;<\/span>\n<\/code><\/pre>\n<p>\u0633\u067e\u0633\u060c \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0628\u0647 \u0641\u06cc\u0644\u062f\u0647\u0627\u06cc \u0645\u0631\u0628\u0648\u0637\u0647 \u0627\u0632 \u0633\u0646\u062f \u062f\u0633\u062a\u0631\u0633\u06cc \u067e\u06cc\u062f\u0627 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ To disable the form from submitting<\/span>\n<span class=\"hljs-keyword\">const<\/span> form = <span class=\"hljs-built_in\">document<\/span>.querySelector(<span class=\"hljs-string\">'#form'<\/span>);\n<span class=\"hljs-comment\">\/\/ To display the error message<\/span>\n<span class=\"hljs-keyword\">const<\/span> errorDiv = <span class=\"hljs-built_in\">document<\/span>.querySelector(<span class=\"hljs-string\">'#show-error'<\/span>);\n<span class=\"hljs-comment\">\/\/ To validate the username<\/span>\n<span class=\"hljs-keyword\">const<\/span> username = <span class=\"hljs-built_in\">document<\/span>.querySelector(<span class=\"hljs-string\">'#username'<\/span>);\n<span class=\"hljs-comment\">\/\/ To validate the password<\/span>\n<span class=\"hljs-keyword\">const<\/span> firstPassword = <span class=\"hljs-built_in\">document<\/span>.querySelector(<span class=\"hljs-string\">'#first-password'<\/span>);\n<span class=\"hljs-comment\">\/\/ To confirm the password<\/span>\n<span class=\"hljs-keyword\">const<\/span> secondPassword = <span class=\"hljs-built_in\">document<\/span>.querySelector(<span class=\"hljs-string\">'#second-password'<\/span>); \n<\/code><\/pre>\n<p>\u0628\u0631\u0627\u06cc \u0633\u0627\u062f\u06af\u06cc\u060c \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0622\u0646 \u0631\u0627 \u0637\u0648\u0631\u06cc \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u0641\u0631\u0645 \u0641\u0642\u0637 \u0628\u0627 \u06a9\u0644\u06cc\u06a9 \u06a9\u0631\u062f\u0646 \u0631\u0648\u06cc <code>submit<\/code> \u062f\u06a9\u0645\u0647\u060c \u0648 \u0646\u0647 \u062f\u0631 \u0632\u0645\u0627\u0646 \u0648\u0627\u0642\u0639\u06cc:<\/p>\n<pre><code class=\"hljs\">form.addEventListener(<span class=\"hljs-string\">'submit'<\/span>, <span class=\"hljs-function\">(<span class=\"hljs-params\">error<\/span>) =&gt;<\/span> {\n     <span class=\"hljs-comment\">\/\/ All validation checks are run in this method.   <\/span>\n}\n<\/code><\/pre>\n<h2 id=\"implementingthevalidators\"><span class=\"ez-toc-section\" id=\"%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%d8%a7%d8%b9%d8%aa%d8%a8%d8%a7%d8%b1_%d8%b3%d9%86%d8%ac%db%8c_%d9%87%d8%a7\"><\/span>\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u0627\u0639\u062a\u0628\u0627\u0631 \u0633\u0646\u062c\u06cc \u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<h3 id=\"firstletteroftheusernameisuppercase\"><span class=\"ez-toc-section\" id=\"%d8%ad%d8%b1%d9%81_%d8%a7%d9%88%d9%84_%d9%86%d8%a7%d9%85_%da%a9%d8%a7%d8%b1%d8%a8%d8%b1%db%8c_%d8%a8%d8%b2%d8%b1%da%af_%d8%a7%d8%b3%d8%aa\"><\/span>\u062d\u0631\u0641 \u0627\u0648\u0644 \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0628\u0632\u0631\u06af \u0627\u0633\u062a<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0627\u06cc\u0646 \u06a9\u0627\u0645\u0644\u0627\u064b \u062a\u0648\u0636\u06cc\u062d\u06cc \u0627\u0633\u062a\u060c \u0627\u06af\u0631 \u062d\u0631\u0641 \u0627\u0648\u0644 \u0631\u0634\u062a\u0647 \u0628\u0627 \u0646\u0648\u0639 \u0628\u0632\u0631\u06af \u0622\u0646 \u06cc\u06a9\u0633\u0627\u0646 \u0628\u0627\u0634\u062f\u060c \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 <code>username<\/code> \u062f\u0631 \u0648\u0627\u0642\u0639 \u0628\u0627 \u06cc\u06a9 \u062d\u0631\u0641 \u0628\u0632\u0631\u06af \u0634\u0631\u0648\u0639 \u0645\u06cc \u0634\u0648\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ We will include any and all errors in this string<\/span>\n<span class=\"hljs-keyword\">let<\/span> incorrectInput = <span class=\"hljs-string\">''<\/span>;\n\n<span class=\"hljs-keyword\">const<\/span> firstLetter = username.value(<span class=\"hljs-number\">0<\/span>);\n\n<span class=\"hljs-comment\">\/\/ Return true if first letter is uppercase<\/span>\n<span class=\"hljs-keyword\">const<\/span> firstLetterIsUpperCase = (firstLetter === firstLetter.toUpperCase()); \n\n<span class=\"hljs-keyword\">if<\/span> (!firstLetterIsUpperCase) {\n    incorrectInput += <span class=\"hljs-string\">' The first letter of username must be uppercase.\\n'<\/span>;\n}\n<\/code><\/pre>\n<h3 id=\"usernamecontainsatleastonedigit\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%a7%d9%85_%da%a9%d8%a7%d8%b1%d8%a8%d8%b1%db%8c_%d8%ad%d8%af%d8%a7%d9%82%d9%84_%d8%b4%d8%a7%d9%85%d9%84_%db%8c%da%a9_%d8%b1%d9%82%d9%85_%d8%a7%d8%b3%d8%aa\"><\/span>\u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u062d\u062f\u0627\u0642\u0644 \u0634\u0627\u0645\u0644 \u06cc\u06a9 \u0631\u0642\u0645 \u0627\u0633\u062a<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p><code>\/\\d\/<\/code>  \u06cc\u06a9 \u0627\u0644\u06af\u0648\u06cc \u0639\u0628\u0627\u0631\u062a \u0645\u0646\u0638\u0645 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627 \u06cc\u06a9 \u0631\u0642\u0645 \u0645\u0646\u0637\u0628\u0642 \u0627\u0633\u062a\u060c \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0639\u0646\u06cc \u06a9\u0647 \u0627\u06af\u0631 \u062d\u062a\u06cc \u06cc\u06a9 \u0628\u0627\u0631 \u0628\u0627 \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0627\u0631\u0627\u0626\u0647 \u0634\u062f\u0647 \u0645\u0637\u0627\u0628\u0642\u062a \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f\u060c \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u062d\u0627\u0648\u06cc \u06cc\u06a9 \u0631\u0642\u0645 \u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ Regex to see if a digit is in the username, returns true if there is<\/span>\n<span class=\"hljs-keyword\">const<\/span> usernameIncludesDigit = <span class=\"hljs-regexp\">\/\\d\/<\/span>.test(username.value); \n\n<span class=\"hljs-keyword\">if<\/span> (!usernameIncludesDigit) {\n    incorrectInput += <span class=\"hljs-string\">'Username must include at least one digit.\\n'<\/span>;\n}\n<\/code><\/pre>\n<h3 id=\"passwordisbetween8and20characterslong\"><span class=\"ez-toc-section\" id=\"%d8%b1%d9%85%d8%b2_%d8%b9%d8%a8%d9%88%d8%b1_%d8%a8%db%8c%d9%86_8_%d8%aa%d8%a7_20_%da%a9%d8%a7%d8%b1%d8%a7%da%a9%d8%aa%d8%b1_%d8%a7%d8%b3%d8%aa\"><\/span>\u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0628\u06cc\u0646 8 \u062a\u0627 20 \u06a9\u0627\u0631\u0627\u06a9\u062a\u0631 \u0627\u0633\u062a<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0631\u0627 <code>length<\/code> \u0648\u06cc\u0698\u06af\u06cc string \u0628\u0627\u06cc\u062f \u062a\u0639\u062f\u0627\u062f \u06a9\u0627\u0631\u0627\u06a9\u062a\u0631\u0647\u0627\u06cc \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0631\u0627 \u0628\u0647 \u0645\u0627 \u0628\u062f\u0647\u062f.  \u06cc\u06a9 \u062f\u0633\u062a\u0648\u0631 \u0634\u0631\u0637\u06cc \u0633\u0627\u062f\u0647 \u0628\u0627\u06cc\u062f \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> badPasswordLength = (firstPassword.value.length &lt; <span class=\"hljs-number\">8<\/span> || firstPassword.value.length &gt; <span class=\"hljs-number\">20<\/span>);\n\n<span class=\"hljs-keyword\">if<\/span> (badPasswordLength) {\n    incorrectInput += <span class=\"hljs-string\">' The password should be within 8 to 20 characters.\\n'<\/span>;\n}\n<\/code><\/pre>\n<h3 id=\"passwordcontainsatleastoneuppercasecharacter\"><span class=\"ez-toc-section\" id=\"%d8%b1%d9%85%d8%b2_%d8%b9%d8%a8%d9%88%d8%b1_%d8%ad%d8%af%d8%a7%d9%82%d9%84_%d8%b4%d8%a7%d9%85%d9%84_%db%8c%da%a9_%d9%86%d9%88%db%8c%d8%b3%d9%87_%d8%a8%d8%b2%d8%b1%da%af_%d8%a7%d8%b3%d8%aa\"><\/span>\u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u062d\u062f\u0627\u0642\u0644 \u0634\u0627\u0645\u0644 \u06cc\u06a9 \u0646\u0648\u06cc\u0633\u0647 \u0628\u0632\u0631\u06af \u0627\u0633\u062a<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0627\u06cc\u0646 \u0634\u0628\u06cc\u0647 \u06a9\u0627\u0631\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u0627 \u0628\u0631\u0627\u06cc \u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc \u0627\u0646\u062c\u0627\u0645 \u062f\u0627\u062f\u06cc\u0645.  \u0641\u0642\u0637 \u0628\u0627\u06cc\u062f \u0639\u0628\u0627\u0631\u062a \u0645\u0646\u0638\u0645 \u0631\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u062f\u0647\u06cc\u0645 \u062a\u0627 \u0628\u0647 \u062c\u0627\u06cc \u0627\u0639\u062f\u0627\u062f\u060c \u062d\u0631\u0648\u0641 \u0628\u0632\u0631\u06af \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-comment\">\/\/ Regex to see if a digit is in the username, returns true if there is<\/span>\n<span class=\"hljs-keyword\">const<\/span> passwordIncludesUppercase = <span class=\"hljs-regexp\">\/(a-z)\/<\/span>.test(firstPassword.value); \n\n<span class=\"hljs-keyword\">if<\/span> (!passwordIncludesUppercase) {\n    incorrectInput += <span class=\"hljs-string\">' The password should contain at least one uppercase character.\\n'<\/span>;\n} \n<\/code><\/pre>\n<h3 id=\"verifythatthetwopasswordsarethesame\"><span class=\"ez-toc-section\" id=\"%d8%a8%d8%b1%d8%b1%d8%b3%db%8c_%da%a9%d9%86%db%8c%d8%af_%da%a9%d9%87_%d8%af%d9%88_%d8%b1%d9%85%d8%b2_%d8%b9%d8%a8%d9%88%d8%b1_%db%8c%da%a9%d8%b3%d8%a7%d9%86_%d9%87%d8%b3%d8%aa%d9%86%d8%af\"><\/span>\u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u062f\u0648 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u06cc\u06a9\u0633\u0627\u0646 \u0647\u0633\u062a\u0646\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0631 \u0646\u0647\u0627\u06cc\u062a \u0628\u0627\u06cc\u062f \u0645\u0642\u0627\u06cc\u0633\u0647 \u06a9\u0646\u06cc\u0645 <code>firstPassword<\/code> \u0628\u0647 <code>secondPassword<\/code> \u0628\u0631\u0627\u06cc \u062f\u06cc\u062f\u0646 \u0627\u06cc\u0646\u06a9\u0647 \u0622\u06cc\u0627 \u0645\u0637\u0627\u0628\u0642\u062a \u062f\u0627\u0631\u0646\u062f \u06cc\u0627 \u062e\u06cc\u0631:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">if<\/span> (firstPassword.value !== secondPassword.value) {\n    incorrectInput += <span class=\"hljs-string\">'The passwords do not match.\\n'<\/span>;\n}\n<\/code><\/pre>\n<h3 id=\"displayingtheerrormessages\"><span class=\"ez-toc-section\" id=\"%d9%86%d9%85%d8%a7%db%8c%d8%b4_%d9%be%db%8c%d8%a7%d9%85_%d9%87%d8%a7%db%8c_%d8%ae%d8%b7%d8%a7\"><\/span>\u0646\u0645\u0627\u06cc\u0634 \u067e\u06cc\u0627\u0645 \u0647\u0627\u06cc \u062e\u0637\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u067e\u0633 \u0627\u0632 \u062a\u0645\u0627\u0645 \u0627\u06cc\u0646 \u0628\u0631\u0631\u0633\u06cc \u0647\u0627\u060c \u0627\u06af\u0631 \u0647\u0631 \u0634\u0631\u0637\u06cc \u0628\u0631\u0622\u0648\u0631\u062f\u0647 \u0646\u0634\u062f\u060c <code>incorrectInput<\/code> \u06cc\u06a9 \u0631\u0634\u062a\u0647 \u062e\u0627\u0644\u06cc \u0646\u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f \u0648 \u062d\u0627\u0648\u06cc \u0645\u0633\u0626\u0644\u0647 \u0645\u0637\u0631\u062d \u0634\u062f\u0647 \u062f\u0631 \u0622\u0646 \u0628\u0644\u0648\u06a9 \u0634\u0631\u0637\u06cc \u0627\u0633\u062a.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a\u060c \u0645\u062a\u0646 \u0631\u0627 \u062f\u0631 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u06cc \u062f\u0647\u06cc\u0645 <code>errorDiv<\/code>  \u0628\u0631\u0627\u06cc \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0646 \u062e\u0637\u0627\u0647\u0627\u06cc\u0645\u0627\u0646 \u0628\u0627 \u0631\u0646\u06af \u0642\u0631\u0645\u0632:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">if<\/span> (incorrectInput !== <span class=\"hljs-string\">\"\"<\/span>) {\n    <span class=\"hljs-comment\">\/\/ Change the error div tag to display the error message(s)<\/span>\n    errorDiv.innerText = incorrectInput; \n    <span class=\"hljs-comment\">\/\/ Change the color of the text to red<\/span>\n    errorDiv.style.color = <span class=\"hljs-string\">'red'<\/span>; \n    <span class=\"hljs-comment\">\/\/ Prevent the form button from submitting again, before fixing the issues<\/span>\n    error.preventDefault(); \n}\n<\/code><\/pre>\n<h3 id=\"testingthecode\"><span class=\"ez-toc-section\" id=\"%d8%aa%d8%b3%d8%aa_%da%a9%d8%af\"><\/span>\u062a\u0633\u062a \u06a9\u062f<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0648 \u0627\u06a9\u0646\u0648\u0646\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0641\u0631\u0645 \u062c\u062f\u06cc\u062f \u062e\u0648\u062f \u0631\u0627 \u0628\u0627 \u0648\u0631\u0648\u062f\u06cc \u0632\u06cc\u0631 \u0622\u0632\u0645\u0627\u06cc\u0634 \u06a9\u0646\u06cc\u0645:<\/p>\n<ul>\n<li>\u0646\u0627\u0645 \u06a9\u0627\u0631\u0628\u0631\u06cc: <code>johndoe<\/code><\/li>\n<li>\u06a9\u0644\u0645\u0647 \u0639\u0628\u0648\u0631: <code>42<\/code><\/li>\n<li>\u062a\u0627\u06cc\u06cc\u062f \u0631\u0645\u0632 \u0639\u0628\u0648\u0631: <code>421<\/code><\/li>\n<\/ul>\n<p>\u06a9\u0647 \u0628\u0627\u06cc\u062f \u0646\u062a\u0627\u06cc\u062c \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0647 \u0647\u0645\u0631\u0627\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/client-side-form-validation-using-vanilla-javascript-3+(2).jpg\" alt=\"\" title=\"\"><\/p>\n<h2 id=\"conclusion\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\"><\/span>\u0646\u062a\u06cc\u062c\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647 \u0627\u0632 \u0648\u0627\u0646\u06cc\u0644\u06cc \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u0631\u0627\u06cc \u062a\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0641\u0631\u0645 \u0633\u0627\u062f\u0647 HTML \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u06cc\u0645.<\/p>\n<p>\u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0645\u0627 \u0631\u0627 \u0642\u0627\u062f\u0631 \u0645\u06cc \u0633\u0627\u0632\u062f \u062a\u0627 \u0628\u0631\u0631\u0633\u06cc \u0647\u0627\u06cc \u0627\u0639\u062a\u0628\u0627\u0631 \u0633\u0646\u062c\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc \u0631\u0627 \u0645\u062a\u0646\u0627\u0633\u0628 \u0628\u0627 \u0645\u0648\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u062f \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u0645.  \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0644\u06af\u0648\u0647\u0627\u06cc \u0633\u0641\u0627\u0631\u0634\u06cc \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u06cc\u06a9 \u0631\u0645\u0632 \u0639\u0628\u0648\u0631 \u0628\u0627\u06cc\u062f \u0645\u0637\u0627\u0628\u0642 \u0628\u0627 \u0622\u0646\u0647\u0627 \u0628\u0627\u0634\u062f \u062a\u0627 \u06a9\u0627\u0631\u0628\u0631 \u0628\u062a\u0648\u0627\u0646\u062f \u062b\u0628\u062a \u0646\u0627\u0645 \u06a9\u0646\u062f \u0631\u0648\u06cc \u0648\u0628\u0633\u0627\u06cc\u062a \u0634\u0645\u0627.<\/p>\n<\/div>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-17 15:03:04<br \/>\n<\/p>\n\n\n<div class=\"kk-star-ratings kksr-auto kksr-align-center kksr-valign-bottom\"\n    data-payload='{&quot;align&quot;:&quot;center&quot;,&quot;id&quot;:&quot;15822&quot;,&quot;slug&quot;:&quot;default&quot;,&quot;valign&quot;:&quot;bottom&quot;,&quot;ignore&quot;:&quot;&quot;,&quot;reference&quot;:&quot;auto&quot;,&quot;class&quot;:&quot;&quot;,&quot;count&quot;:&quot;0&quot;,&quot;legendonly&quot;:&quot;&quot;,&quot;readonly&quot;:&quot;&quot;,&quot;score&quot;:&quot;0&quot;,&quot;starsonly&quot;:&quot;&quot;,&quot;best&quot;:&quot;5&quot;,&quot;gap&quot;:&quot;5&quot;,&quot;greet&quot;:&quot;\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628&quot;,&quot;legend&quot;:&quot;0\\\/5 (0 \u0631\u0627\u06cc)&quot;,&quot;size&quot;:&quot;30&quot;,&quot;title&quot;:&quot;\u0627\u0639\u062a\u0628\u0627\u0631\u0633\u0646\u062c\u06cc \u0641\u0631\u0645 \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a Vanilla \u0627\u0645\u0631\u0648\u0632\u0647 \u0627\u06a9\u062b\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0648\u0628 \u0627\u0632 \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u0646\u062f \u06a9\u0647 \u06cc\u06a9 \u0641\u0631\u0645 \u0631\u0627 \u067e\u0631 \u06a9\u0646\u06cc\u062f\u060c \u0686\u0647 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0628\u0627\u0646\u06a9\u06cc \u0622\u0646\u0644\u0627\u06cc\u0646 \u06cc\u0627 \u06cc\u06a9 \u0633\u0631\u0648\u06cc\u0633 \u067e\u062e\u0634 \u0645\u0648\u0633\u06cc\u0642\u06cc.  \u0648 \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0646\u0647\u0627\u06cc\u06cc \u0647\u0631\u06af\u0632 \u0642\u0627\u0628\u0644 \u0627\u0639\u062a\u0645\u0627\u062f \u0646\u06cc\u0633\u062a\u0646\u062f\u060c \u0628\u0627\u06cc\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u0641\u0631\u06cc\u0628 \u062f\u0647\u06cc\u0645 \u062a\u0627 \u062a\u0634\u062e\u06cc\u0635 \u062f\u0647\u062f \u06a9\u0647 \u0648\u0631\u0648\u062f\u06cc \u0646\u0627\u062f\u0631\u0633\u062a \u0627\u0633\u062a...&quot;,&quot;width&quot;:&quot;0&quot;,&quot;_legend&quot;:&quot;{score}\\\/{best} ({count} \u0631\u0627\u06cc)&quot;,&quot;font_factor&quot;:&quot;1.25&quot;}'>\n            \n<div class=\"kksr-stars\">\n    \n<div class=\"kksr-stars-inactive\">\n            <div class=\"kksr-star\" data-star=\"1\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"2\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"3\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"4\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"5\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n    \n<div class=\"kksr-stars-active\" style=\"width: 0px;\">\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n<\/div>\n                \n\n<div class=\"kksr-legend\" style=\"font-size: 24px;\">\n            <span class=\"kksr-muted\">\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628<\/span>\n    <\/div>\n    <\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 4<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0645\u0639\u0631\u0641\u06cc \u0627\u0645\u0631\u0648\u0632\u0647 \u0627\u06a9\u062b\u0631 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0648\u0628 \u0627\u0632 \u0634\u0645\u0627 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u0646\u062f \u06a9\u0647 \u06cc\u06a9 \u0641\u0631\u0645 \u0631\u0627 \u067e\u0631 \u06a9\u0646\u06cc\u062f\u060c \u0686\u0647 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0628\u0627\u0646\u06a9\u06cc \u0622\u0646\u0644\u0627\u06cc\u0646 \u06cc\u0627 \u06cc\u06a9 \u0633\u0631\u0648\u06cc\u0633 \u067e\u062e\u0634 \u0645\u0648\u0633\u06cc\u0642\u06cc. \u0648 \u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0646\u0647\u0627\u06cc\u06cc \u0647\u0631\u06af\u0632 \u0642\u0627\u0628\u0644 \u0627\u0639\u062a\u0645\u0627\u062f \u0646\u06cc\u0633\u062a\u0646\u062f\u060c \u0628\u0627\u06cc\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u0627\u062d\u0645\u0642 \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0648\u0631\u0648\u062f\u06cc \u0646\u0627\u062f\u0631\u0633\u062a \u0627\u0633\u062a \u062a\u0634\u062e\u06cc\u0635 \u062f\u0647\u062f \u0648 \u0622\u0646 \u0631\u0627 \u0628\u0627 \u06cc\u06a9 \u067e\u06cc\u0627\u0645 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":15823,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[1842,3357,1252,1964,1844,2341,3906,2233,1776,1811,1786,1781,2294,4228,3351,4221,1779,4224,1800,1909,4225,4223,2428,4153,1780,1103,1961,4222,1802,2179,3452,1803,2342,3611,2842,1914,3320,4229,3270,1815,3269,1806,1795,3462,4226,1790,4230,2322,3936,3438,1785,4227,2829,2855,1831,1813],"class_list":["post-15822","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","category-programming","tag-nodejs-vps","tag-vanilla","tag--nodejs","tag----frontend","tag-1844","tag-2341","tag-3906","tag-2233","tag-1776","tag-1811","tag-1786","tag-1781","tag-2294","tag-4228","tag-3351","tag-4221","tag-1779","tag-4224","tag-1800","tag-1909","tag-4225","tag-4223","tag-2428","tag-4153","tag-1780","tag-1103","tag-1961","tag-4222","tag-1802","tag-2179","tag-3452","tag-1803","tag-2342","tag-3611","tag-2842","tag-1914","tag-3320","tag-4229","tag-3270","tag-1815","tag-3269","tag-1806","tag-1795","tag-3462","tag-4226","tag-1790","tag-4230","tag-2322","tag-3936","tag-3438","tag-1785","tag-4227","tag-2829","tag-2855","tag-1831","tag-1813"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15822","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/users\/3"}],"replies":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/comments?post=15822"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15822\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/15823"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=15822"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=15822"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=15822"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}