{"id":15084,"date":"2024-01-08T12:15:15","date_gmt":"2024-01-08T08:45:15","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86-%d8%a8%d8%a7%d8%b1%da%af%db%8c%d8%b1%db%8c-%d8%af%d8%b1-react-%d8%a7%d8%b2-%d8%a7%d8%a8%d8%aa\/"},"modified":"2024-01-08T12:15:15","modified_gmt":"2024-01-08T08:45:15","slug":"%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86-%d8%a8%d8%a7%d8%b1%da%af%db%8c%d8%b1%db%8c-%d8%af%d8%b1-react-%d8%a7%d8%b2-%d8%a7%d8%a8%d8%aa","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86-%d8%a8%d8%a7%d8%b1%da%af%db%8c%d8%b1%db%8c-%d8%af%d8%b1-react-%d8%a7%d8%b2-%d8%a7%d8%a8%d8%aa\/","title":{"rendered":"\u0631\u0648\u0634 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u062f\u0631 React \u0627\u0632 \u0627\u0628\u062a\u062f\u0627 \u0647\u0646\u06af\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc React \u06a9\u0647 \u0645\u062d\u062a\u0648\u0627 \u0631\u0627 \u0627\u0632 \u0645\u0646\u0627\u0628\u0639 \u062e\u0627\u0631\u062c\u06cc \u0648\u0627\u06a9\u0634\u06cc \u0645\u06cc \u06a9\u0646\u0646\u062f \u0648 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0622\u0646 \u0645\u062f\u062a\u06cc \u0637\u0648\u0644 \u0645\u06cc \u06a9\u0634\u062f\u060c \u0647\u0645\u06cc\u0634\u0647 \u0627\u06cc\u062f\u0647 \u062e\u0648\u0628\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627 \u062f\u0631\u06af\u06cc\u0631 \u06a9\u0631\u062f\u0646 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0648 \u062d\u0641\u0638 \u062a\u0648\u062c\u0647 \u0622\u0646\u0647\u0627 \u0628\u0627 \u0644\u0648\u062f\u0631\u060c \u062a\u062c\u0631\u0628\u0647 \u0627\u06cc \u062f\u0644\u067e\u0630\u06cc\u0631 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0641\u0631\u0627\u0647\u0645 \u06a9\u0646\u06cc\u062f. \u0627\u06cc\u0646 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u06a9\u0645\u06a9 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0628\u0641\u0647\u0645\u0646\u062f \u0686\u0647 \u0627\u062a\u0641\u0627\u0642\u06cc \u0645\u06cc \u0627\u0641\u062a\u062f \u0631\u0648\u06cc \u0628\u0647 \u062c\u0627\u06cc \u0631\u0641\u062a\u0646&#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%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86-%d8%a8%d8%a7%d8%b1%da%af%db%8c%d8%b1%db%8c-%d8%af%d8%b1-react-%d8%a7%d8%b2-%d8%a7%d8%a8%d8%aa\/#%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%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86-%d8%a8%d8%a7%d8%b1%da%af%db%8c%d8%b1%db%8c-%d8%af%d8%b1-react-%d8%a7%d8%b2-%d8%a7%d8%a8%d8%aa\/#%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%db%8c%da%a9_sample_react_app\" >\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 Sample React App<\/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%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86-%d8%a8%d8%a7%d8%b1%da%af%db%8c%d8%b1%db%8c-%d8%af%d8%b1-react-%d8%a7%d8%b2-%d8%a7%d8%a8%d8%aa\/#%d8%a8%d8%a7_react_%e2%80%93_gif_%d9%88_css_%db%8c%da%a9_%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86_%d9%84%d9%88%d8%af%d8%b1_%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%da%a9%d9%86%db%8c%d8%af\" >\u0628\u0627 React &#8211; GIF \u0648 CSS \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0644\u0648\u062f\u0631 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-4\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86-%d8%a8%d8%a7%d8%b1%da%af%db%8c%d8%b1%db%8c-%d8%af%d8%b1-react-%d8%a7%d8%b2-%d8%a7%d8%a8%d8%aa\/#%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%db%8c%da%a9_%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86_%d9%84%d9%88%d8%af%d8%b1_%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_gif\" >\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0644\u0648\u062f\u0631 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 GIF<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-5\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86-%d8%a8%d8%a7%d8%b1%da%af%db%8c%d8%b1%db%8c-%d8%af%d8%b1-react-%d8%a7%d8%b2-%d8%a7%d8%a8%d8%aa\/#%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%db%8c%da%a9_%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86_%d9%84%d9%88%d8%af%d8%b1_%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_css\" >\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0644\u0648\u062f\u0631 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 CSS<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86-%d8%a8%d8%a7%d8%b1%da%af%db%8c%d8%b1%db%8c-%d8%af%d8%b1-react-%d8%a7%d8%b2-%d8%a7%d8%a8%d8%aa\/#%d8%b1%d9%88%d8%b4_%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%db%8c%da%a9_%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86_%d8%af%d8%b1_%d8%ad%d8%a7%d9%84_%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c_%d8%af%d8%b1_react\" >\u0631\u0648\u0634 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u062f\u0631 \u062d\u0627\u0644 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u062f\u0631 React<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86-%d8%a8%d8%a7%d8%b1%da%af%db%8c%d8%b1%db%8c-%d8%af%d8%b1-react-%d8%a7%d8%b2-%d8%a7%d8%a8%d8%aa\/#%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%db%8c%da%a9_%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86_%d8%af%d8%b1_%d8%ad%d8%a7%d9%84_%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c_%d9%87%d9%86%da%af%d8%a7%d9%85_%d8%af%d8%b1%d8%ae%d9%88%d8%a7%d8%b3%d8%aa_%d9%85%d8%ad%d8%aa%d9%88%d8%a7_%d8%a7%d8%b2_%db%8c%da%a9_api\" >\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u062f\u0631 \u062d\u0627\u0644 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0647\u0646\u06af\u0627\u0645 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0645\u062d\u062a\u0648\u0627 \u0627\u0632 \u06cc\u06a9 API<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d9%88%d8%b4-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86-%d8%a8%d8%a7%d8%b1%da%af%db%8c%d8%b1%db%8c-%d8%af%d8%b1-react-%d8%a7%d8%b2-%d8%a7%d8%a8%d8%aa\/#%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\"> 6<\/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>\u0647\u0646\u06af\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc React \u06a9\u0647 \u0645\u062d\u062a\u0648\u0627 \u0631\u0627 \u0627\u0632 \u0645\u0646\u0627\u0628\u0639 \u062e\u0627\u0631\u062c\u06cc \u0648\u0627\u06a9\u0634\u06cc \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f \u0648 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0622\u0646 \u0645\u062f\u062a\u06cc \u0637\u0648\u0644 \u0645\u06cc\u200c\u06a9\u0634\u062f\u060c \u0647\u0645\u06cc\u0634\u0647 \u0627\u06cc\u062f\u0647 \u062e\u0648\u0628\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627 \u062f\u0631\u06af\u06cc\u0631 \u06a9\u0631\u062f\u0646 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0648 \u062d\u0641\u0638 \u062a\u0648\u062c\u0647 \u0622\u0646\u200c\u0647\u0627 \u0628\u0627 \u0644\u0648\u062f\u0631\u060c \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u06cc \u062f\u0644\u067e\u0630\u06cc\u0631\u06cc \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u062f\u0647\u06cc\u062f\u060c \u0632\u06cc\u0631\u0627 \u0627\u06cc\u0646 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u06a9\u0645\u06a9 \u0645\u06cc\u200c\u06a9\u0646\u062f \u0628\u0641\u0647\u0645\u0646\u062f \u0686\u0647 \u0627\u062a\u0641\u0627\u0642\u06cc \u0645\u06cc\u200c\u0627\u0641\u062a\u062f. \u0631\u0648\u06cc \u0628\u0647 \u062c\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0628\u0647 \u062d\u062f\u0633 \u0648 \u06af\u0645\u0627\u0646 \u0631\u0647\u0627 \u06a9\u0646\u06cc\u0645.<\/p>\n<blockquote>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0631\u0648\u0634 \u0646\u0645\u0627\u06cc\u0634 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0644\u0648\u062f\u0631 \u0647\u0646\u06af\u0627\u0645 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0648 \u0628\u0627\u0632\u06cc\u0627\u0628\u06cc \u0645\u062d\u062a\u0648\u0627 \u0627\u0632 \u0645\u0646\u0627\u0628\u0639 \u062e\u0627\u0631\u062c\u06cc \u0631\u0627 \u06cc\u0627\u062f \u062e\u0648\u0627\u0647\u06cc\u0645 \u06af\u0631\u0641\u062a.  \u0645\u0627 \u0647\u0645 \u0627\u0632 \u06cc\u06a9 \u0627\u0633\u067e\u06cc\u0646\u0631 GIF \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0648 \u0647\u0645 \u06cc\u06a9 \u0627\u0633\u067e\u06cc\u0646\u0631 \u0627\u0632 \u0627\u0628\u062a\u062f\u0627 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 CSS \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<\/blockquote>\n<p>\u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0645\u0646\u0638\u0648\u0631 &#8211; \u0645\u0627 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u06a9\u0648\u0686\u06a9 \u0645\u06cc\u200c\u0633\u0627\u0632\u06cc\u0645 \u06a9\u0647 \u0645\u0638\u0646\u0647\u200c\u0647\u0627 \u0631\u0627 \u0648\u0627\u06a9\u0634\u06cc \u0645\u06cc\u200c\u06a9\u0646\u062f\u060c \u0628\u0627 \u0635\u0641\u062d\u0647 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u062f\u0631 \u062d\u06cc\u0646 \u0648\u0627\u06a9\u0634\u06cc \u06cc\u06a9 \u0645\u0638\u0646\u0647:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/how-to-create-a-loading-animation-in-react-from-scratch-2.gif\" alt=\"react-loading-animation-example\" title=\"\"><\/p>\n<blockquote>\n<p>\u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0631 \u0645\u0648\u0631\u062f \u0622\u0646 \u0628\u06cc\u0634\u062a\u0631 \u0628\u062f\u0627\u0646\u06cc\u062f <code>react-spinners<\/code> &#8211; \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0627\u06cc \u0628\u0627 \u0627\u0633\u067e\u06cc\u0646\u0631\u0647\u0627\u06cc \u0627\u0632 \u067e\u06cc\u0634 \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647\u060c \u0645\u0627 \u0631\u0627 \u0628\u062e\u0648\u0627\u0646\u06cc\u062f <em>&#8220;\u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u062f\u0631 React \u0628\u0627 react-spinners \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645&#8221;<\/em>!<\/p>\n<\/blockquote>\n<h2 id=\"creatingasamplereactapp\"><span class=\"ez-toc-section\" id=\"%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%db%8c%da%a9_sample_react_app\"><\/span>\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 Sample React App<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0627 \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0646\u0634\u0627\u0646\u0647 \u06af\u0630\u0627\u0631\u06cc React \u062e\u0648\u062f \u0634\u0631\u0648\u0639 \u06a9\u0646\u06cc\u0645.  \u0627\u0635\u0648\u0644\u0627\u064b \u0645\u0627 \u062f\u0648 \u062a\u0627 \u062f\u0627\u0631\u06cc\u0645 <code>&lt;div&gt;<\/code> \u0639\u0646\u0627\u0635\u0631 \u062f\u0631 <em>\u0648\u0627\u0644\u062f\u06cc\u0646<\/em> <code>&lt;div&gt;<\/code>  (\u0628\u0647 \u062e\u0627\u0637\u0631 \u0633\u0627\u062f\u06af\u06cc) &#8211; \u06cc\u06a9\u06cc \u0627\u0633\u062a <code>loader-container<\/code> \u0648 \u062f\u0648\u0645\u06cc \u0627\u0633\u062a <code>main-content<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> React <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'react'<\/span>;\n\n<span class=\"hljs-keyword\">const<\/span> App = <span class=\"hljs-function\">() =&gt;<\/span> {\n  <span class=\"hljs-keyword\">return<\/span> (\n    <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"container\"<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"loader-container\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"spinner\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/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> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"main-content\"<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>Hello World!<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n          This is a demo Project to show how to add animated loading with React.\n        <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"buttons\"<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"btn\"<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">a<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"#\"<\/span>&gt;<\/span>Read Article<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">a<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"btn get-quote\"<\/span>&gt;<\/span>\n            Generate Quote\n          <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&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\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"quote-section\"<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">blockquote<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"quote\"<\/span>&gt;<\/span>\n            If you do not express your own original ideas, if you do not listen\n            to your own being, you will have betrayed yourself.\n          <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">blockquote<\/span>&gt;<\/span>\n          - <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">span<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"author\"<\/span>&gt;<\/span>Rollo May<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&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\">div<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\n  );\n};\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> App;\n<\/code><\/pre>\n<p>\u062a\u0627 \u06a9\u0646\u0648\u0646\u060c \u0645\u0627 \u0641\u0642\u0637 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 <code>&lt;div&gt;<\/code> \u0628\u0631\u0627\u06cc \u0644\u0648\u062f\u0631 \u0645\u0627  \u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0631\u0648\u0634\u200c\u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641 \u0628\u0631\u0627\u06cc \u0628\u0647 \u062f\u0633\u062a \u0622\u0648\u0631\u062f\u0646 \u0644\u0648\u062f\u0631 \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0631\u0648\u0634 \u0638\u0627\u0647\u0631 \u06a9\u0631\u062f\u0646 \u0622\u0646 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u0645 \u0631\u0648\u06cc \u06cc\u06a9 \u062c\u0632\u0621\u060c \u06cc\u0627 \u062d\u062a\u06cc \u0622\u0646 \u0631\u0627 \u062f\u0631 \u06a9\u0644 \u0635\u0641\u062d\u0647 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0647\u06cc\u062f.<\/p>\n<div class=\"alert alert-note\">\n<div class=\"flex\">\n<div class=\"flex-shrink-0 mr-3\"><\/div>\n<div class=\"w-full\">\n<p><strong>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f <a rel=\"nofollow noopener noreferrer\" target=\"_blank\" href=\"https:\/\/github.com\/olawanlejoel\/loader-anim\">\u0627\u06cc\u0646 \u0645\u062e\u0632\u0646<\/a> \u0648 \u062f\u0631 \u0635\u0648\u0631\u062a \u0646\u06cc\u0627\u0632 \u0647\u0646\u06af\u0627\u0645 \u062e\u0648\u0627\u0646\u062f\u0646 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u06a9\u062f \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0646\u06cc\u062f.<\/p>\n<\/p><\/div><\/div><\/div>\n<h2 id=\"createaloaderanimationwithreactgifandcss\"><span class=\"ez-toc-section\" id=\"%d8%a8%d8%a7_react_%e2%80%93_gif_%d9%88_css_%db%8c%da%a9_%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86_%d9%84%d9%88%d8%af%d8%b1_%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%da%a9%d9%86%db%8c%d8%af\"><\/span>\u0628\u0627 React &#8211; GIF \u0648 CSS \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0644\u0648\u062f\u0631 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u0648\u0644\u06cc\u0646 \u06a9\u0627\u0631\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0642\u0628\u0644 \u0627\u0632 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0644\u0648\u062f\u0631 \u062f\u0631 React \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645 \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u062e\u0648\u062f \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0631\u0627 \u0628\u0633\u0627\u0632\u06cc\u0645.  \u0631\u0627\u0647 \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645\u060c \u0627\u0645\u0627\u060c \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647\u060c \u0628\u0647 \u062f\u0648 \u0645\u0648\u0631\u062f \u0627\u0632 \u0622\u0646\u0647\u0627 \u0646\u06af\u0627\u0647\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u0627\u0646\u062f\u0627\u062e\u062a &#8211; <em>GIF<\/em> \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0647\u0627 \u0648 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0647\u0627\u06cc CSS.<\/p>\n<h3 id=\"creatingaloaderanimationusinggifs\"><span class=\"ez-toc-section\" id=\"%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%db%8c%da%a9_%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86_%d9%84%d9%88%d8%af%d8%b1_%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_gif\"><\/span>\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0644\u0648\u062f\u0631 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 GIF<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0622 <em>GIF<\/em> \u06cc\u06a9 \u062a\u0635\u0648\u06cc\u0631 \u0645\u062a\u062d\u0631\u06a9 \u0627\u0633\u062a \u06a9\u0647 (\u0645\u06cc \u062a\u0648\u0627\u0646\u062f) \u0628\u06cc \u0646\u0647\u0627\u06cc\u062a \u062e\u0648\u062f \u0631\u0627 \u0628\u062f\u0648\u0646 \u0645\u06a9\u062b \u062a\u06a9\u0631\u0627\u0631 \u06a9\u0646\u062f.  \u0628\u0627 \u0647\u0631 \u06a9\u062f\u0648\u0645 \u062f\u0631\u0633\u062a \u0645\u06cc\u0634\u0647 <em>GIF<\/em> \u0633\u0627\u0632\u0646\u062f\u0647 \u06cc\u0627 \u0627\u0632 \u0627\u0628\u062a\u062f\u0627 \u0628\u0627 \u0627\u0628\u0632\u0627\u0631 \u0637\u0631\u0627\u062d\u06cc.  \u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0645\u0627 <a rel=\"nofollow noopener noreferrer\" href=\"https:\/\/media.giphy.com\/media\/8agqybiK5LW8qrG3vJ\/giphy.gif\" target=\"_blank\">\u0627\u0632 \u0627\u06cc\u0646 GIF \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u062f \u06a9\u0631\u062f<\/a> \u0648 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u067e\u0633 \u0632\u0645\u06cc\u0646\u0647 \u0627\u0632 <code>loader-container<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-selector-class\">.loader-container<\/span> {\n    <span class=\"hljs-attribute\">width<\/span>: <span class=\"hljs-number\">100%<\/span>;\n    <span class=\"hljs-attribute\">height<\/span>: <span class=\"hljs-number\">100vh<\/span>;\n    <span class=\"hljs-attribute\">position<\/span>: fixed;\n    <span class=\"hljs-attribute\">background<\/span>: <span class=\"hljs-built_in\">rgba<\/span>(<span class=\"hljs-number\">0<\/span>, <span class=\"hljs-number\">0<\/span>, <span class=\"hljs-number\">0<\/span>, <span class=\"hljs-number\">0.834<\/span>)\n        <span class=\"hljs-built_in\">url<\/span>(<span class=\"hljs-string\">\"https:\/\/media.giphy.com\/media\/8agqybiK5LW8qrG3vJ\/giphy.gif\"<\/span>) center\n        no-repeat;\n    <span class=\"hljs-attribute\">z-index<\/span>: <span class=\"hljs-number\">1<\/span>;\n}\n<\/code><\/pre>\n<div class=\"alert alert-note\">\n<div class=\"flex\">\n<div class=\"flex-shrink-0 mr-3\"><\/div>\n<div class=\"w-full\">\n<p><strong>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0647\u0645\u06cc\u0646 GIF \u0631\u0627 \u0631\u0648\u06cc \u0639\u0646\u0627\u0635\u0631 \u062f\u06cc\u06af\u0631 \u0646\u06cc\u0632 \u0627\u0639\u0645\u0627\u0644 \u06a9\u0646\u06cc\u062f \u062a\u0627 \u0645\u062d\u062f\u0648\u062f\u0647 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0631\u0627 \u0628\u0648\u0645\u06cc \u0633\u0627\u0632\u06cc \u06a9\u0646\u06cc\u062f.<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u06a9\u062f \u0628\u0627\u0644\u0627 \u0628\u0647 \u0645\u0627 \u062f\u0631 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u067e\u0633\u200c\u0632\u0645\u06cc\u0646\u0647 \u0633\u06cc\u0627\u0647 \u06a9\u0645\u06a9 \u0645\u06cc\u200c\u06a9\u0646\u062f \u06a9\u0647 \u0642\u0628\u0644 \u0627\u0632 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0646 \u0646\u0645\u0627\u062f \u0644\u0648\u062f\u0631 \u062f\u0631 \u0645\u0631\u06a9\u0632\u060c \u06a9\u0644 \u0635\u0641\u062d\u0647 \u0631\u0627 \u067e\u0648\u0634\u0634 \u062f\u0647\u062f.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0645\u0627 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u0627\u062c\u0631\u0627 \u0645\u06cc \u06a9\u0646\u06cc\u0645\u060c <code>loader-container<\/code> \u0627\u06a9\u0646\u0648\u0646 \u062f\u0631 \u0628\u0627\u0644\u0627 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f \u0632\u06cc\u0631\u0627 \u0645\u0627 \u0622\u0646 \u0631\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0631\u062f\u06cc\u0645 <code>z-index<\/code> \u0628\u0647 1:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/how-to-create-a-loading-animation-in-react-from-scratch-1.png\" alt=\"\" title=\"\"><\/p>\n<p>\u0639\u0627\u0644\u06cc!  \u0645\u0627 \u06cc\u06a9 \u0635\u0641\u062d\u0647 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 a \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 <em>GIF<\/em> \u062a\u0635\u0648\u06cc\u0631 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0644\u0648\u062f\u0631  \u0631\u0627\u0647\u200c\u0647\u0627\u06cc \u0628\u06cc\u200c\u0634\u0645\u0627\u0631\u06cc \u062f\u06cc\u06af\u0631 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0647 \u062e\u0648\u062f\u0645\u0627\u0646 \u0627\u0633\u062a\u0627\u06cc\u0644 \u0628\u062f\u0647\u06cc\u0645 <code>loader-container<\/code> \u0628\u0631\u0627\u06cc \u0627\u0641\u06a9\u062a \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641  \u062d\u0627\u0644 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0628\u06cc\u0646\u06cc\u0645 \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u06cc\u0646 \u0644\u0648\u062f\u0631 \u0631\u0627 \u0628\u0627 CSS \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645\u060c \u0648 \u0627\u0632 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062a\u0635\u0627\u0648\u06cc\u0631 \u062e\u0627\u0631\u062c\u06cc \u0627\u062c\u062a\u0646\u0627\u0628 \u06a9\u0646\u06cc\u0645\u060c \u06a9\u0647 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u062f \u0628\u0627\u0631 \u0632\u06cc\u0627\u062f\u06cc \u0631\u0627 \u0627\u0632 \u0646\u0638\u0631 \u0632\u0645\u0627\u0646 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u062f.<\/p>\n<h3 id=\"creatingaloaderanimationusingcss\"><span class=\"ez-toc-section\" id=\"%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%db%8c%da%a9_%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86_%d9%84%d9%88%d8%af%d8%b1_%d8%a8%d8%a7_%d8%a7%d8%b3%d8%aa%d9%81%d8%a7%d8%af%d9%87_%d8%a7%d8%b2_css\"><\/span>\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0644\u0648\u062f\u0631 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 CSS<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>CSS \u06cc\u06a9 \u0632\u0628\u0627\u0646 \u0631\u0633\u0627 \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u0645\u0627 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0633\u0628\u06a9 \u0647\u0627\u06cc \u0645\u062e\u062a\u0644\u0641\u06cc \u0645\u0627\u0646\u0646\u062f \u062a\u0631\u0633\u06cc\u0645 \u0627\u0634\u06a9\u0627\u0644\u060c \u062a\u0648\u0635\u06cc\u0641 \u062a\u0631\u062a\u06cc\u0628 \u0646\u0633\u0628\u06cc \u0639\u0646\u0627\u0635\u0631 \u0648 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0622\u0646\u0647\u0627\u060c \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u062a\u0635\u0627\u0648\u06cc\u0631 \u0648 \u062d\u062a\u06cc \u0645\u062a\u062d\u0631\u06a9 \u0633\u0627\u0632\u06cc \u0622\u0646\u0647\u0627 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645. \u0631\u0648\u06cc \u0646\u06cc\u0627\u0632\u0647\u0627\u06cc \u0645\u0627  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u062e\u06cc\u0644\u06cc \u0633\u0627\u062f\u0647 \u0628\u0633\u0627\u0632\u06cc\u0645 <em>\u0627\u0633\u067e\u06cc\u0646\u0631 \u0644\u0648\u062f\u0631<\/em>.<\/p>\n<p>\u0628\u0647 \u06cc\u0627\u062f \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06a9\u0647 \u0645\u0627 \u06cc\u06a9 \u0627\u0633\u067e\u06cc\u0646\u0631 \u062f\u0627\u0634\u062a\u06cc\u0645 <code>&lt;div&gt;<\/code> \u062f\u0631\u0648\u0646 container \u062f\u0631 \u0645\u0627 <code>load-container<\/code> \u0646\u0634\u0627\u0646\u0647 \u06af\u0630\u0627\u0631\u06cc\u061f  \u0627\u06af\u0631\u0686\u0647 \u0642\u0628\u0644\u0627\u064b \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0646\u0645\u06cc \u06a9\u0631\u062f\u06cc\u0645\u060c \u0627\u06a9\u0646\u0648\u0646 \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0627\u06cc\u0644 \u062f\u0627\u062f\u0646 \u0628\u0647 \u0646\u0645\u0627\u062f \u0648 \u0633\u067e\u0633 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>load-container<\/code> \u0628\u0631\u0627\u06cc \u0648\u0633\u0637 \u0646\u0645\u0627\u062f \u0644\u0648\u062f\u0631:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-selector-class\">.loader-container<\/span> {\n    <span class=\"hljs-attribute\">width<\/span>: <span class=\"hljs-number\">100%<\/span>;\n    <span class=\"hljs-attribute\">height<\/span>: <span class=\"hljs-number\">100vh<\/span>;\n    <span class=\"hljs-attribute\">display<\/span>: flex;\n    <span class=\"hljs-attribute\">justify-content<\/span>: center;\n    <span class=\"hljs-attribute\">align-items<\/span>: center;\n    <span class=\"hljs-attribute\">position<\/span>: fixed;\n    <span class=\"hljs-attribute\">background<\/span>: <span class=\"hljs-built_in\">rgba<\/span>(<span class=\"hljs-number\">0<\/span>, <span class=\"hljs-number\">0<\/span>, <span class=\"hljs-number\">0<\/span>, <span class=\"hljs-number\">0.834<\/span>);\n    <span class=\"hljs-attribute\">z-index<\/span>: <span class=\"hljs-number\">1<\/span>;\n}\n\n<span class=\"hljs-selector-class\">.spinner<\/span> {\n    <span class=\"hljs-attribute\">width<\/span>: <span class=\"hljs-number\">64px<\/span>;\n    <span class=\"hljs-attribute\">height<\/span>: <span class=\"hljs-number\">64px<\/span>;\n    <span class=\"hljs-attribute\">border<\/span>: <span class=\"hljs-number\">8px<\/span> solid;\n    <span class=\"hljs-attribute\">border-color<\/span>: <span class=\"hljs-number\">#3d5af1<\/span> transparent <span class=\"hljs-number\">#3d5af1<\/span> transparent;\n    <span class=\"hljs-attribute\">border-radius<\/span>: <span class=\"hljs-number\">50%<\/span>;\n    <span class=\"hljs-attribute\">animation<\/span>: spin-anim <span class=\"hljs-number\">1.2s<\/span> linear infinite;\n}\n\n<span class=\"hljs-keyword\">@keyframes<\/span> spin-anim {\n    <span class=\"hljs-number\">0%<\/span> {\n        <span class=\"hljs-attribute\">transform<\/span>: <span class=\"hljs-built_in\">rotate<\/span>(<span class=\"hljs-number\">0deg<\/span>);\n    }\n    <span class=\"hljs-number\">100%<\/span> {\n        <span class=\"hljs-attribute\">transform<\/span>: <span class=\"hljs-built_in\">rotate<\/span>(<span class=\"hljs-number\">360deg<\/span>);\n    }\n}\n<\/code><\/pre>\n<p>\u0628\u0627 CSS &#8211; \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0631\u0648\u0634 \u0627\u0646\u062c\u0627\u0645 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0631\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u062f\u0642\u06cc\u0642 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u0645.  \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627\u060c \u0645\u0627 GIF \u0631\u0627 \u0627\u0632 \u0642\u0628\u0644 \u0628\u0627\u0632\u0633\u0627\u0632\u06cc \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645!  \u062a\u0627 \u06a9\u0646\u0648\u0646\u060c \u062f\u0648 \u0631\u0648\u06cc\u06a9\u0631\u062f \u0627\u0635\u0644\u06cc \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0644\u0648\u062f\u0631 \u0631\u0627 \u0645\u0648\u0631\u062f \u0628\u062d\u062b \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0647 \u0627\u06cc\u0645.  \u062d\u0627\u0644\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0646\u06af\u0627\u0647\u06cc \u0628\u06cc\u0646\u062f\u0627\u0632\u06cc\u0645 \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0639\u0645\u0644\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<h2 id=\"howtocreatealoadinganimationinreact\"><span class=\"ez-toc-section\" id=\"%d8%b1%d9%88%d8%b4_%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%db%8c%da%a9_%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86_%d8%af%d8%b1_%d8%ad%d8%a7%d9%84_%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c_%d8%af%d8%b1_react\"><\/span>\u0631\u0648\u0634 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u062f\u0631 \u062d\u0627\u0644 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u062f\u0631 React<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u062f\u0631 React \u0628\u0627 \u0631\u0648\u0634 \u0627\u0646\u062c\u0627\u0645 \u0622\u0646 \u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0645\u062a\u0641\u0627\u0648\u062a \u0627\u0633\u062a \u0632\u06cc\u0631\u0627 \u0645\u0627 \u0627\u06a9\u0646\u0648\u0646 \u0627\u0632 <em>\u062d\u0627\u0644\u062a<\/em> \u0648 <em>\u0627\u067e\u0631\u0627\u062a\u0648\u0631\u0647\u0627\u06cc \u0633\u0647 \u062a\u0627\u06cc\u06cc<\/em> \u0628\u0631\u0627\u06cc \u06a9\u0646\u062a\u0631\u0644 \u0632\u0645\u0627\u0646 \u0638\u0627\u0647\u0631 \u0634\u062f\u0646 \u0648 \u0646\u0627\u067e\u062f\u06cc\u062f \u0634\u062f\u0646 \u0644\u0648\u062f\u0631.  \u0645\u0627 \u0646\u06cc\u0632 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f <code>useEffect()<\/code> hook  \u0628\u0631\u0627\u06cc \u0627\u0637\u0645\u06cc\u0646\u0627\u0646 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u06cc\u06a9 \u0644\u0648\u062f\u0631 \u0628\u0631\u0627\u06cc \u0645\u062f\u062a \u0632\u0645\u0627\u0646 \u0627\u0632 \u067e\u06cc\u0634 \u062a\u0639\u06cc\u06cc\u0646 \u0634\u062f\u0647 \u062f\u0631 \u062d\u06cc\u0646 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0638\u0627\u0647\u0631 \u0645\u06cc \u0634\u0648\u062f.  \u0627\u0648\u0644\u06cc\u0646 \u0642\u062f\u0645 \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 import \u0647\u0631 \u062f\u0648 \u0642\u0644\u0627\u0628 \u0645\u0631\u0628\u0648\u0637\u0647\u060c \u0628\u0647 \u062f\u0646\u0628\u0627\u0644 \u0627\u06cc\u062c\u0627\u062f \u062d\u0627\u0644\u062a \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0645\u0627:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> React, { useState, useEffect } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'react'<\/span>;\n\n<span class=\"hljs-keyword\">const<\/span> App = <span class=\"hljs-function\">() =&gt;<\/span> {\n  <span class=\"hljs-keyword\">const<\/span> (loading, setLoading) = useState(<span class=\"hljs-literal\">false<\/span>);\n\n  <span class=\"hljs-keyword\">return<\/span> (\n       &lt;!-- ... --&gt;\n  );\n};\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> App;\n<\/code><\/pre>\n<div class=\"alert alert-note\">\n<div class=\"flex\">\n<div class=\"flex-shrink-0 mr-3\"><\/div>\n<div class=\"w-full\">\n<p><strong>\u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f:<\/strong> \u062f\u0648\u0644\u062a \u062a\u0646\u0638\u06cc\u0645 \u0634\u062f\u0647 \u0627\u0633\u062a <code>false<\/code> \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u062f\u0631 \u06a9\u062f \u0628\u0627\u0644\u0627\u060c \u0648 \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0622\u0646 \u0631\u0627 \u0628\u0647 <code>true<\/code> \u0647\u0631 \u0632\u0645\u0627\u0646 \u06a9\u0647 \u0645\u0627 \u0628\u062e\u0648\u0627\u0647\u06cc\u0645 <code>loader-container<\/code> \u0638\u0627\u0647\u0631 \u0634\u062f\u0646.<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639\u060c \u0627\u0632 <code>setTimeout()<\/code> \u0631\u0648\u0634\u06cc \u06a9\u0647 \u0628\u0647 \u0644\u0648\u062f\u0631 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u0628\u0647 \u0645\u062f\u062a 2 \u062b\u0627\u0646\u06cc\u0647 \u0638\u0627\u0647\u0631 \u0634\u0648\u062f \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 page \u062f\u0631 \u062d\u0627\u0644 \u0627\u0631\u0627\u0626\u0647 \u0627\u0633\u062a.  \u0627\u06cc\u0646 \u0648\u0642\u0641\u0647 \u06cc\u06a9 \u062a\u0645\u0627\u0633 API \u06af\u0631\u0627\u0646 \u0642\u06cc\u0645\u062a \u0631\u0627 \u0634\u0628\u06cc\u0647 \u0633\u0627\u0632\u06cc \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0628\u0627\u0632\u06af\u0634\u062a \u0646\u062a\u0627\u06cc\u062c \u0628\u0647 \u0632\u0645\u0627\u0646 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> React, { useState, useEffect } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'react'<\/span>;\n\n<span class=\"hljs-keyword\">const<\/span> App = <span class=\"hljs-function\">() =&gt;<\/span> {\n  <span class=\"hljs-keyword\">const<\/span> (loading, setLoading) = useState(<span class=\"hljs-literal\">false<\/span>);\n\n  useEffect(<span class=\"hljs-function\">() =&gt;<\/span> {\n    setLoading(<span class=\"hljs-literal\">true<\/span>);\n    <span class=\"hljs-built_in\">setTimeout<\/span>(<span class=\"hljs-function\">() =&gt;<\/span> {\n      setLoading(<span class=\"hljs-literal\">false<\/span>);\n    }, <span class=\"hljs-number\">2000<\/span>);\n  }, ());\n\n  <span class=\"hljs-keyword\">return<\/span> (\n    <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"container\"<\/span>&gt;<\/span>\n        <span class=\"hljs-comment\">&lt;!-- ... --&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\n  );\n};\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> App;\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0628\u062f\u0627\u0646 \u0645\u0639\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0647\u0631 \u0632\u0645\u0627\u0646 \u06a9\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0631\u0646\u062f\u0631 \u0645\u06cc \u0634\u0648\u062f\u060c \u0645\u0627 <code>loader-container<\/code> \u0628\u0627\u06cc\u062f \u0628\u0647 \u0645\u062f\u062a 2 \u062b\u0627\u0646\u06cc\u0647 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647 \u0634\u0648\u062f.  \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u06cc\u06a9 \u0639\u0645\u0644\u06af\u0631 \u0633\u0647 \u062a\u0627\u06cc\u06cc \u0628\u0631\u0627\u06cc \u06a9\u0646\u062a\u0631\u0644 \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 <code>loader-container<\/code> \u0648 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0631\u0627 \u062f\u0631 \u0627\u06cc\u0646 \u0628\u0627\u0632\u0647 \u0632\u0645\u0627\u0646\u06cc \u0646\u0645\u0627\u06cc\u0634 \u062f\u0647\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> React, { useState, useEffect } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'react'<\/span>;\n\n<span class=\"hljs-keyword\">const<\/span> App = <span class=\"hljs-function\">() =&gt;<\/span> {\n  <span class=\"hljs-keyword\">const<\/span> (loading, setLoading) = useState(<span class=\"hljs-literal\">false<\/span>);\n  useEffect(<span class=\"hljs-function\">() =&gt;<\/span> {\n    setLoading(<span class=\"hljs-literal\">true<\/span>);\n    <span class=\"hljs-built_in\">setTimeout<\/span>(<span class=\"hljs-function\">() =&gt;<\/span> {\n      setLoading(<span class=\"hljs-literal\">false<\/span>);\n    }, <span class=\"hljs-number\">2000<\/span>);\n  }, ());\n\n  <span class=\"hljs-keyword\">return<\/span> (\n    <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"container\"<\/span>&gt;<\/span>\n      {loading ? (\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"loader-container\"<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"spinner\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/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> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"main-content\"<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>Hello World!<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n            This is a demo Project to show how to add animated loading with\n            React.\n          <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"buttons\"<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"btn\"<\/span>&gt;<\/span>\n              <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">a<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"#\"<\/span>&gt;<\/span>Read Article<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">a<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"btn get-quote\"<\/span>&gt;<\/span>\n              Generate Quote\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&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\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"quote-section\"<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">blockquote<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"quote\"<\/span>&gt;<\/span>{quote.content}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">blockquote<\/span>&gt;<\/span>-{' '}\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">span<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"author\"<\/span>&gt;<\/span>{quote.author}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&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\">div<\/span>&gt;<\/span>\n      )}\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\n  );\n};\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> App;\n<\/code><\/pre>\n<p>\u0686\u0647 \u0632\u0645\u0627\u0646\u06cc <code>loading<\/code> \u062a\u0646\u0638\u06cc\u0645 \u0634\u062f\u0647 \u0627\u0633\u062a <code>true<\/code>\u060c \u0627\u067e\u0631\u0627\u062a\u0648\u0631 \u0633\u0647 \u062a\u0627\u06cc\u06cc \u062f\u0631 \u06a9\u062f \u0642\u0628\u0644\u06cc \u0646\u0634\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f <code>loader-container<\/code>.  \u062f\u0631 \u063a\u06cc\u0631 \u0627\u06cc\u0646 \u0635\u0648\u0631\u062a\u060c \u0622\u0646 \u0631\u0627 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u062f <code>main-content<\/code>.<\/p>\n<blockquote>\n<p>\u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0631 \u0645\u0648\u0631\u062f \u0639\u0645\u0644\u06af\u0631\u0647\u0627\u06cc \u0633\u0647 \u062a\u0627\u06cc\u06cc \u0628\u06cc\u0634\u062a\u0631 \u0628\u062e\u0648\u0627\u0646\u06cc\u062f &#8211; \u0645\u0627 \u0631\u0627 \u0628\u062e\u0648\u0627\u0646\u06cc\u062f <em>&#8220;\u0631\u0627\u0647\u0646\u0645\u0627\u06cc \u0627\u067e\u0631\u0627\u062a\u0648\u0631 \u0633\u0647 \u062a\u0627\u06cc\u06cc \u062f\u0631 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a&#8221;<\/em>!<\/p>\n<\/blockquote>\n<h2 id=\"implementingaloadinganimationwhenrequestingcontentfromanapi\"><span class=\"ez-toc-section\" id=\"%d9%be%db%8c%d8%a7%d8%af%d9%87_%d8%b3%d8%a7%d8%b2%db%8c_%db%8c%da%a9_%d8%a7%d9%86%db%8c%d9%85%db%8c%d8%b4%d9%86_%d8%af%d8%b1_%d8%ad%d8%a7%d9%84_%d8%a8%d8%a7%d8%b1%da%af%d8%b0%d8%a7%d8%b1%db%8c_%d9%87%d9%86%da%af%d8%a7%d9%85_%d8%af%d8%b1%d8%ae%d9%88%d8%a7%d8%b3%d8%aa_%d9%85%d8%ad%d8%aa%d9%88%d8%a7_%d8%a7%d8%b2_%db%8c%da%a9_api\"><\/span>\u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u062f\u0631 \u062d\u0627\u0644 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0647\u0646\u06af\u0627\u0645 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0645\u062d\u062a\u0648\u0627 \u0627\u0632 \u06cc\u06a9 API<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0633\u0646\u0627\u0631\u06cc\u0648\u06cc \u062f\u06cc\u06af\u0631\u06cc \u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0627\u0641\u0631\u0627\u062f \u0627\u0632 \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u062f\u0631 React \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f\u060c \u0632\u0645\u0627\u0646\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0645\u062d\u062a\u0648\u0627 \u0631\u0627 \u0627\u0632 \u06cc\u06a9 \u0645\u0646\u0628\u0639 \u062e\u0627\u0631\u062c\u06cc \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f\u060c \u0632\u06cc\u0631\u0627 \u0627\u06cc\u0646 \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u062e\u0627\u0631\u062c\u06cc \u0647\u0633\u062a\u0646\u062f \u0648 \u062a\u062d\u0648\u06cc\u0644 \u0622\u0646\u200c\u0647\u0627 \u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0632\u0645\u0627\u0646\u200c\u0647\u0627\u06cc \u067e\u0631\u062f\u0627\u0632\u0634 \u067e\u06cc\u0634\u200c\u0628\u06cc\u0646\u06cc\u200c\u0634\u062f\u0647\u060c \u062a\u062d\u062a \u062a\u0623\u062b\u06cc\u0631 \u0631\u0648\u06cc\u062f\u0627\u062f\u0647\u0627\u06cc \u062e\u0627\u0631\u062c\u06cc \u0645\u062e\u062a\u0644\u0641\u06cc \u0627\u0633\u062a.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0646\u0642\u0644 \u0642\u0648\u0644 \u062a\u0635\u0627\u062f\u0641\u06cc \u0627\u0632 Random Quotes API \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06a9\u0646\u06cc\u0645 \u0648 \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0631 \u062d\u0627\u0644\u062a \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u06cc\u0645 \u0648 \u067e\u0633 \u0627\u0632 \u0622\u0646 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0646\u0645\u0627\u06cc\u0634 \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u062f. \u0631\u0648\u06cc \u0635\u0641\u062d\u0647 \u0646\u0645\u0627\u06cc\u0634  \u0647\u0631 \u0632\u0645\u0627\u0646 \u06a9\u0647 \u0645\u0627 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u06cc \u0627\u0631\u0633\u0627\u0644 \u06a9\u0646\u06cc\u0645\u060c <code>loading<\/code> \u062d\u0627\u0644\u062a \u062a\u0646\u0638\u06cc\u0645 \u062e\u0648\u0627\u0647\u062f \u0634\u062f <code>true<\/code>.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0645\u062d\u062a\u0648\u0627 \u0648\u0627\u06a9\u0634\u06cc \u0634\u062f\u060c \u0622\u0646 \u0631\u0627 \u0628\u0647 \u062d\u0627\u0644\u062a \u0627\u0648\u0644\u06cc\u0647 \u062a\u0646\u0638\u06cc\u0645 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>false<\/code>\u060c \u062a\u0648\u0642\u0641 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> React, { useState, useEffect } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'react'<\/span>;\n\n<span class=\"hljs-keyword\">const<\/span> App = <span class=\"hljs-function\">() =&gt;<\/span> {\n  <span class=\"hljs-keyword\">const<\/span> (loading, setLoading) = useState(<span class=\"hljs-literal\">false<\/span>);\n  <span class=\"hljs-keyword\">const<\/span> (quote, setQuote) = useState({});\n\n  <span class=\"hljs-keyword\">const<\/span> getRandomQuote = <span class=\"hljs-function\">() =&gt;<\/span> {\n    setLoading(<span class=\"hljs-literal\">true<\/span>);\n    fetch(<span class=\"hljs-string\">'https:\/\/api.quotable.io\/random'<\/span>)\n      .then(<span class=\"hljs-function\">(<span class=\"hljs-params\">res<\/span>) =&gt;<\/span> res.json())\n      .then(<span class=\"hljs-function\">(<span class=\"hljs-params\">data<\/span>) =&gt;<\/span> {\n        setLoading(<span class=\"hljs-literal\">false<\/span>);\n        setQuote(data);\n      });\n  };\n\n  <span class=\"hljs-keyword\">return<\/span> (\n    <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"container\"<\/span>&gt;<\/span>\n      {loading ? (\n        <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"loader-container\"<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"spinner\"<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/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> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"main-content\"<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span>&gt;<\/span>Hello World!<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n            This is a demo Project to show how to add animated loading with\n            React.\n          <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n          <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"buttons\"<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"btn\"<\/span>&gt;<\/span>\n              <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">a<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"#\"<\/span>&gt;<\/span>Read Article<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">a<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"btn get-quote\"<\/span> <span class=\"hljs-attr\">onClick<\/span>=<span class=\"hljs-string\">{getRandomQuote}<\/span>&gt;<\/span>\n              Generate Quote\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&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\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"quote-section\"<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">blockquote<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"quote\"<\/span>&gt;<\/span>{quote.content}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">blockquote<\/span>&gt;<\/span>-{' '}\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">span<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"author\"<\/span>&gt;<\/span>{quote.author}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&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\">div<\/span>&gt;<\/span>\n      )}\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\n  );\n};\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> App;\n<\/code><\/pre>\n<p>\u0645\u0627 \u06cc\u06a9 \u0627\u0633\u067e\u06cc\u0646\u0631 \u067e\u0627\u0633\u062e\u06af\u0648 \u0627\u0632 \u0627\u0628\u062a\u062f\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645!  \u0628\u0647 \u0637\u0648\u0631 \u0645\u062a\u0646\u0627\u0648\u0628\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 <code>react-spinner<\/code> \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0627\u06cc \u06a9\u0647 \u062f\u0627\u0631\u0627\u06cc \u0637\u06cc\u0641 \u06af\u0633\u062a\u0631\u062f\u0647 \u0627\u06cc \u0627\u0632 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0647\u0627\u06cc \u0644\u0648\u062f\u0631 \u0627\u0633\u062a.<\/p>\n<blockquote>\n<p>\u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0631 \u0645\u0648\u0631\u062f \u0622\u0646 \u0628\u06cc\u0634\u062a\u0631 \u0628\u062f\u0627\u0646\u06cc\u062f <code>react-spinners<\/code> &#8211; \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0627\u06cc \u0628\u0627 \u0627\u0633\u067e\u06cc\u0646\u0631\u0647\u0627\u06cc \u0627\u0632 \u067e\u06cc\u0634 \u0633\u0627\u062e\u062a\u0647 \u0634\u062f\u0647\u060c \u0645\u0627 \u0631\u0627 \u0628\u062e\u0648\u0627\u0646\u06cc\u062f <em>&#8220;\u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u062f\u0631 React \u0628\u0627 react-spinners \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645&#8221;<\/em>!<\/p>\n<\/blockquote>\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 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0645\u0627 \u06cc\u0627\u062f \u06af\u0631\u0641\u062a\u06cc\u0645 \u06a9\u0647 \u0686\u06af\u0648\u0646\u0647 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062f\u0648 \u0631\u0648\u06cc\u06a9\u0631\u062f \u0645\u062e\u062a\u0644\u0641\u060c \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0631\u0627 \u0628\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 React \u062e\u0648\u062f \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645.  \u0645\u0627 \u06cc\u06a9 GIF \u0633\u0627\u062f\u0647 \u0648\u0627\u0631\u062f \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645 \u0648 \u06cc\u06a9 \u0627\u0633\u067e\u06cc\u0646\u0631 \u0627\u0632 \u0627\u0628\u062a\u062f\u0627 \u0628\u0627 CSS \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645.  \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0631\u0648\u0634 \u0627\u062f\u063a\u0627\u0645 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u062f\u0631 \u06cc\u06a9 \u0645\u062d\u06cc\u0637 \u0648\u0627\u0642\u0639\u06cc\u200c\u062a\u0631 \u0627\u0646\u062f\u0627\u062e\u062a\u0647\u200c\u0627\u06cc\u0645 &#8211; \u0648\u0627\u06a9\u0634\u06cc \u062f\u0627\u062f\u0647\u200c\u0647\u0627 \u0627\u0632 \u06cc\u06a9 API \u0648 \u0646\u0645\u0627\u06cc\u0634 \u0627\u0641\u06a9\u062a \u062f\u0631 \u062d\u06cc\u0646 \u0627\u0646\u062a\u0638\u0627\u0631 \u0628\u0631\u0627\u06cc \u0646\u062a\u06cc\u062c\u0647.<\/p>\n<\/div>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-08 12:15:03<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;15084&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;\u0631\u0648\u0634 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0627\u0646\u06cc\u0645\u06cc\u0634\u0646 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u062f\u0631 React \u0627\u0632 \u0627\u0628\u062a\u062f\u0627 \u0647\u0646\u06af\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc React \u06a9\u0647 \u0645\u062d\u062a\u0648\u0627 \u0631\u0627 \u0627\u0632 \u0645\u0646\u0627\u0628\u0639 \u062e\u0627\u0631\u062c\u06cc \u0648\u0627\u06a9\u0634\u06cc \u0645\u06cc \u06a9\u0646\u0646\u062f \u0648 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0622\u0646 \u0645\u062f\u062a\u06cc \u0637\u0648\u0644 \u0645\u06cc \u06a9\u0634\u062f\u060c \u0647\u0645\u06cc\u0634\u0647 \u0627\u06cc\u062f\u0647 \u062e\u0648\u0628\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627 \u062f\u0631\u06af\u06cc\u0631 \u06a9\u0631\u062f\u0646 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0648 \u062d\u0641\u0638 \u062a\u0648\u062c\u0647 \u0622\u0646\u0647\u0627 \u0628\u0627 \u0644\u0648\u062f\u0631\u060c \u062a\u062c\u0631\u0628\u0647 \u0627\u06cc \u062f\u0644\u067e\u0630\u06cc\u0631 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0641\u0631\u0627\u0647\u0645 \u06a9\u0646\u06cc\u062f. \u0627\u06cc\u0646 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u06a9\u0645\u06a9 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u0628\u0641\u0647\u0645\u0646\u062f \u0686\u0647 \u0627\u062a\u0641\u0627\u0642\u06cc \u0645\u06cc \u0627\u0641\u062a\u062f \u0631\u0648\u06cc \u0628\u0647 \u062c\u0627\u06cc \u0631\u0641\u062a\u0646...&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\"> 6<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0645\u0639\u0631\u0641\u06cc \u0647\u0646\u06af\u0627\u0645 \u0627\u06cc\u062c\u0627\u062f \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0647\u0627\u06cc React \u06a9\u0647 \u0645\u062d\u062a\u0648\u0627 \u0631\u0627 \u0627\u0632 \u0645\u0646\u0627\u0628\u0639 \u062e\u0627\u0631\u062c\u06cc \u0648\u0627\u06a9\u0634\u06cc \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f \u0648 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0622\u0646 \u0645\u062f\u062a\u06cc \u0637\u0648\u0644 \u0645\u06cc\u200c\u06a9\u0634\u062f\u060c \u0647\u0645\u06cc\u0634\u0647 \u0627\u06cc\u062f\u0647 \u062e\u0648\u0628\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0628\u0627 \u062f\u0631\u06af\u06cc\u0631 \u06a9\u0631\u062f\u0646 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0648 \u062d\u0641\u0638 \u062a\u0648\u062c\u0647 \u0622\u0646\u200c\u0647\u0627 \u0628\u0627 \u0644\u0648\u062f\u0631\u060c \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u06cc \u062f\u0644\u067e\u0630\u06cc\u0631\u06cc \u0631\u0627 \u0627\u0631\u0627\u0626\u0647 \u062f\u0647\u06cc\u062f\u060c \u0632\u06cc\u0631\u0627 \u0627\u06cc\u0646 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u06a9\u0645\u06a9 \u0645\u06cc\u200c\u06a9\u0646\u062f \u0628\u0641\u0647\u0645\u0646\u062f \u0686\u0647 \u0627\u062a\u0641\u0627\u0642\u06cc \u0645\u06cc\u200c\u0627\u0641\u062a\u062f. \u0631\u0648\u06cc \u0628\u0647 \u062c\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0622\u0646\u0647\u0627 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":15078,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[1827,1828,1100,1842,2508,1844,1938,2341,1904,2103,2348,3604,1776,1811,3605,3598,2051,1936,2359,1789,1779,2822,3597,1814,1909,3603,1807,2428,3411,3523,3606,1961,3338,3631,3349,2750,3602,3331,1803,3637,2123,2667,3633,3636,2122,1815,1892,3634,2004,2110,2425,1806,1795,3635,674,3632,3459,1790,1966,2408,1785,2273,1983,2199,1813],"class_list":["post-15084","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","category-programming","tag-react","tag-1828","tag-javascript","tag-nodejs-vps","tag--javascript","tag-1844","tag-1938","tag-2341","tag-1904","tag-2103","tag-2348","tag-3604","tag-1776","tag-1811","tag-3605","tag-3598","tag-2051","tag-1936","tag-2359","tag-1789","tag-1779","tag-2822","tag-3597","tag-1814","tag-1909","tag-3603","tag-1807","tag-2428","tag-3411","tag-3523","tag-3606","tag-1961","tag-3338","tag-3631","tag-3349","tag-2750","tag-3602","tag-3331","tag-1803","tag-3637","tag-2123","tag-2667","tag-3633","tag-3636","tag-2122","tag-1815","tag-1892","tag-3634","tag-2004","tag-2110","tag-2425","tag-1806","tag-1795","tag-3635","tag-674","tag-3632","tag-3459","tag-1790","tag--javascrip","tag-2408","tag-1785","tag-2273","tag-1983","tag-2199","tag-1813"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15084","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=15084"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15084\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/15078"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=15084"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=15084"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=15084"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}