{"id":15529,"date":"2024-01-13T13:58:40","date_gmt":"2024-01-13T10:28:40","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/"},"modified":"2024-01-13T13:58:40","modified_gmt":"2024-01-13T10:28:40","slug":"%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/","title":{"rendered":"\u0631\u0627\u0647\u0646\u0645\u0627\u06cc \u0634\u0631\u0648\u0639 \u0628\u0647 \u06a9\u0627\u0631 \u0628\u0627 Next.js &#8211; \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 Next.js AppNext.js \u06cc\u06a9 \u0686\u0627\u0631\u0686\u0648\u0628 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0645\u0646\u0628\u0639 \u0628\u0627\u0632 \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0637 Vercel \u0628\u0631\u0627\u06cc \u0628\u0647\u0628\u0648\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc React \u0628\u0627 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f \u0631\u0646\u062f\u0631 \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0648 \u062a\u0648\u0644\u06cc\u062f \u0633\u0627\u06cc\u062a \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0627\u06cc\u062c\u0627\u062f \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0628\u0647 \u0637\u0648\u0631 \u0633\u0646\u062a\u06cc\u060c React \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06cc\u06a9 \u0635\u0641\u062d\u0647 \u0627\u06cc (SPA) \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f \u06a9\u0647 \u0645\u062d\u062a\u0648\u0627\u06cc \u0622\u0646\u0647\u0627 \u0631\u0646\u062f\u0631 \u0645\u06cc \u0634\u0648\u062f. \u0631\u0648\u06cc \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc  Next.js \u0628\u0627 \u0627\u062c\u0627\u0632\u0647 \u062f\u0627\u062f\u0646 \u0628\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f&#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%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%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%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%d9%86%d8%b5%d8%a8_%d9%88_%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c\" >\u0646\u0635\u0628 \u0648 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc<\/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%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%d9%88%db%8c%da%98%da%af%db%8c_%d9%87%d8%a7%db%8c_nextjs\" >\u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc Next.js<\/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%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%d8%b5%d9%81%d8%ad%d8%a7%d8%aa\" >\u0635\u0641\u062d\u0627\u062a<\/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%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%d8%b5%d9%81%d8%ad%d8%a7%d8%aa_%d9%be%db%8c%d8%b4_%d8%b1%d9%86%d8%af%d8%b1\" >\u0635\u0641\u062d\u0627\u062a \u067e\u06cc\u0634 \u0631\u0646\u062f\u0631<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#_%d8%b3%d8%a6%d9%88\" >&#038; \u0633\u0626\u0648<\/a><\/li><\/ul><\/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%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c_api_%d8%a8%d8%a7_nextjs\" >\u0627\u06cc\u062c\u0627\u062f \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc API \u0628\u0627 Next.js<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-8\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%d8%af%d8%a7%d8%b1%d8%a7%db%8c%db%8c_%d9%87%d8%a7%db%8c_%d8%a7%db%8c%d8%b3%d8%aa%d8%a7\" >\u062f\u0627\u0631\u0627\u06cc\u06cc \u0647\u0627\u06cc \u0627\u06cc\u0633\u062a\u0627<\/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%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%d9%85%d8%aa%d8%ba%db%8c%d8%b1%d9%87%d8%a7%db%8c_%d9%85%d8%ad%db%8c%d8%b7%db%8c_nextjs\" >\u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u06cc\u0637\u06cc Next.js<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-10\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%d8%b3%d8%a7%d8%ae%d8%aa_%d8%a7%d9%be%d9%84%db%8c%da%a9%db%8c%d8%b4%d9%86_%d8%a2%d8%a8_%d9%88_%d9%87%d9%88%d8%a7_%d8%a8%d8%a7_nextjs\" >\u0633\u0627\u062e\u062a \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0628\u0627 Next.js<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-11\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%d9%86%d8%b4%d8%a7%d9%86%d9%87_%da%af%d8%b0%d8%a7%d8%b1%db%8c_%d8%b5%d9%81%d8%ad%d9%87\" >\u0646\u0634\u0627\u0646\u0647 \u06af\u0630\u0627\u0631\u06cc \u0635\u0641\u062d\u0647<\/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%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%d8%af%d8%b1%db%8c%d8%a7%d9%81%d8%aa_%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa_%d8%a2%d8%a8_%d9%88_%d9%87%d9%88%d8%a7\" >\u062f\u0631\u06cc\u0627\u0641\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-13\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%d8%b0%d8%ae%db%8c%d8%b1%d9%87_%d8%af%d8%a7%d8%af%d9%87_%d9%87%d8%a7_%d8%a8%d9%87_%d8%b5%d9%88%d8%b1%d8%aa_%d9%85%d8%ad%d9%84%db%8c\" >\u0630\u062e\u06cc\u0631\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u0645\u062d\u0644\u06cc<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-14\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%d8%b5%d9%81%d8%ad%d9%87_%d8%aa%d8%a7%d8%b1%db%8c%d8%ae%da%86%d9%87_%d8%a2%d8%a8_%d9%88_%d9%87%d9%88%d8%a7\" >\u0635\u0641\u062d\u0647 \u062a\u0627\u0631\u06cc\u062e\u0686\u0647 \u0622\u0628 \u0648 \u0647\u0648\u0627<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-15\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%b1%d8%a7%d9%87%d9%86%d9%85%d8%a7%db%8c-%d8%b4%d8%b1%d9%88%d8%b9-%d8%a8%d9%87-%da%a9%d8%a7%d8%b1-%d8%a8%d8%a7-next-js-%d8%a7%db%8c%d8%ac%d8%a7%d8%af-%db%8c%da%a9-next-js-appnext-js-%db%8c%da%a9\/#%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\"> 15<\/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>Next.js \u06cc\u06a9 \u0686\u0627\u0631\u0686\u0648\u0628 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0645\u0646\u0628\u0639 \u0628\u0627\u0632 \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0637 Vercel \u0628\u0631\u0627\u06cc \u0628\u0647\u0628\u0648\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc React \u0628\u0627 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f <strong><em>\u0631\u0646\u062f\u0631 \u0633\u0645\u062a \u0633\u0631\u0648\u0631<\/em><\/strong>  \u0648 <strong><em>\u062a\u0648\u0644\u06cc\u062f \u0633\u0627\u06cc\u062a \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9<\/em><\/strong>.<\/p>\n<p>\u0628\u0647 \u0637\u0648\u0631 \u0633\u0646\u062a\u06cc\u060c React \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f <strong><em>\u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u062a\u06a9 \u0635\u0641\u062d\u0647 \u0627\u06cc (SPA)<\/em><\/strong>  \u06a9\u0647 \u0645\u0637\u0627\u0644\u0628 \u0622\u0646 \u0627\u0631\u0627\u0626\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0631\u0648\u06cc \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc  Next.js \u0628\u0627 \u0627\u062c\u0627\u0632\u0647 \u062f\u0627\u062f\u0646 \u0628\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0642\u062f\u0627\u0645\u0627\u062a \u0633\u0645\u062a \u0633\u0631\u0648\u0631\u060c \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u067e\u06cc\u0634 \u0648\u0627\u06a9\u0634\u06cc \u0648 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0627\u0632 TypeScript \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u0646\u062f\u060c \u0627\u06cc\u0646 \u0631\u0627 \u06af\u0633\u062a\u0631\u0634 \u0645\u06cc \u062f\u0647\u062f.  \u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646 &#8211; \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u0627\u0636\u0627\u0641\u06cc \u0646\u062f\u0627\u0631\u062f!<\/p>\n<blockquote>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0648\u06cc\u0698\u06af\u06cc\u200c\u0647\u0627 \u0648 \u0639\u0645\u0644\u06a9\u0631\u062f\u0647\u0627\u06cc \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 Next.js \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u0627\u0634\u062a.  \u0628\u0631\u0627\u06cc \u062a\u062d\u06a9\u06cc\u0645 \u062f\u0627\u0646\u0634 \u062c\u062f\u06cc\u062f\u060c \u0645\u0627 \u06cc\u06a9 \u0645\u062c\u0645\u0648\u0639\u0647 \u06a9\u0627\u0645\u0644 \u0686\u0646\u062f\u06af\u0627\u0646\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u0633\u0627\u062e\u062apage \u0628\u0631\u0646\u0627\u0645\u0647 \u0622\u0628 \u0648 \u0647\u0648\u0627 \u06a9\u0647 \u0628\u0627 API \u0647\u0627\u06cc \u062e\u0627\u0631\u062c\u06cc \u0635\u062d\u0628\u062a \u0645\u06cc \u06a9\u0646\u062f \u0648 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u062d\u0627\u0644\u062a \u0647\u0627\u06cc \u062f\u0627\u062f\u0647 \u0634\u062f\u0647 \u0631\u0627 \u0636\u0628\u0637 \u06a9\u0646\u062f.<\/p>\n<\/blockquote>\n<h2 id=\"installationandsetup\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%b5%d8%a8_%d9%88_%d8%b1%d8%a7%d9%87_%d8%a7%d9%86%d8%af%d8%a7%d8%b2%db%8c\"><\/span>\u0646\u0635\u0628 \u0648 \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0633\u0627\u062f\u0647 \u062a\u0631\u06cc\u0646 \u0631\u0627\u0647 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Next.js \u062c\u062f\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>create-next-app<\/code> \u0627\u0628\u0632\u0627\u0631 CLI.  \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0622\u0646 \u0631\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f <code>npm<\/code>:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm install create-next-app<\/span>\n<\/code><\/pre>\n<p>\u067e\u0633 \u0627\u0632 \u0646\u0635\u0628\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Next.js \u062c\u062f\u06cc\u062f \u0631\u0627 \u0628\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0627\u0628\u0632\u0627\u0631 \u0648 \u0627\u0631\u0627\u0626\u0647 \u06cc\u06a9 \u0646\u0627\u0645 \u0628\u0631\u0627\u06cc \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npx create-next-app weather-app<\/span>\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> \u0627\u06af\u0631 \u0642\u0628\u0644\u0627\u064b \u0646\u062f\u0627\u0631\u06cc\u062f <code>create-next-app<\/code> \u0646\u0635\u0628 \u0634\u062f\u0647 \u0627\u0633\u062a &#8211; <code>npx<\/code> \u0627\u0632 \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u062f \u06a9\u0647 \u0622\u0646 \u0631\u0627 \u0628\u0647 \u0637\u0648\u0631 \u062e\u0648\u062f\u06a9\u0627\u0631 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f.<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0627\u0628\u0632\u0627\u0631 \u0622\u0645\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u06cc\u06a9 \u067e\u0631\u0648\u0698\u0647 \u0627\u0633\u06a9\u0644\u062a \u0631\u0627 \u0628\u0647 \u067e\u0627\u06cc\u0627\u0646 \u0631\u0633\u0627\u0646\u062f\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0647 \u0641\u0647\u0631\u0633\u062a \u0631\u0627\u0647\u0646\u0645\u0627 \u0628\u0631\u0648\u06cc\u0645 \u0648 \u0628\u0647 \u062f\u0627\u062e\u0644 \u0622\u0646 \u0646\u06af\u0627\u0647\u06cc \u0628\u06cc\u0646\u062f\u0627\u0632\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> <span class=\"hljs-built_in\">cd<\/span> weather-app<\/span>\n<span class=\"hljs-meta\">$<\/span><span class=\"bash\"> ls<\/span>\nREADME.md       node_modules\/      package.json  public\/\nnext.config.js  package-lock.json  pages\/        styles\/\n<\/code><\/pre>\n<p>\u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f <code>package.json<\/code>\u060c <code>package-lock.json<\/code> \u0648 <code>node_modules<\/code> \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f\u060c \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0645\u0627 \u0646\u06cc\u0632 \u0628\u0627\u06cc\u062f <code>\/pages<\/code>\u060c <code>\/public<\/code> \u0648 <code>\/styles<\/code> \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0647\u0627\u060c \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 a <code>next.config.js<\/code> \u0641\u0627\u06cc\u0644!<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u0646\u06af\u0627\u0647\u06cc \u0628\u0647 \u0627\u06cc\u0646\u0647\u0627 \u0628\u06cc\u0646\u062f\u0627\u0632\u06cc\u0645.<\/p>\n<h2 id=\"featuresofnextjs\"><span class=\"ez-toc-section\" id=\"%d9%88%db%8c%da%98%da%af%db%8c_%d9%87%d8%a7%db%8c_nextjs\"><\/span>\u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc Next.js<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>Next.js \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a \u06cc\u06a9 \u0627\u0641\u0632\u0648\u0646\u0647 \u0628\u0631\u0627\u06cc React \u0627\u0633\u062a \u0648 \u0686\u0646\u062f \u0686\u06cc\u0632 \u062c\u062f\u06cc\u062f \u0631\u0627 \u0645\u0639\u0631\u0641\u06cc \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u062a\u0648\u0633\u0639\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 React \u0631\u0627 \u0633\u0627\u062f\u0647 \u062a\u0631 \u0648 \u0633\u0631\u06cc\u0639 \u062a\u0631 \u0645\u06cc \u06a9\u0646\u062f &#8211; \u0628\u0627 \u0634\u0631\u0648\u0639 <em>\u0635\u0641\u062d\u0627\u062a Next.js<\/em>.<\/p>\n<h3 id=\"pages\"><span class=\"ez-toc-section\" id=\"%d8%b5%d9%81%d8%ad%d8%a7%d8%aa\"><\/span>\u0635\u0641\u062d\u0627\u062a<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>Next.js \u0627\u06cc\u062c\u0627\u062f \u0686\u0646\u062fpage \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0628\u0627 React \u0628\u0647 \u0637\u0631\u0632 \u0645\u0633\u062e\u0631\u0647 \u0627\u06cc \u0628\u0627 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0622\u0646 \u0622\u0633\u0627\u0646 \u0627\u0633\u062a <strong><em>\u0631\u0648\u062a\u0631 \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u0633\u06cc\u0633\u062a\u0645 \u0641\u0627\u06cc\u0644<\/em><\/strong>.  \u0634\u0645\u0627 \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u0646\u0635\u0628 \u0647\u06cc\u0686 \u0628\u0633\u062a\u0647 \u0627\u0636\u0627\u0641\u06cc \u0646\u062f\u0627\u0631\u06cc\u062f\u060c \u0645\u0627\u0646\u0646\u062f <code>react-router-dom<\/code>\u060c \u06cc\u0627 \u0627\u0635\u0644\u0627\u064b \u06cc\u06a9 \u0631\u0648\u062a\u0631 \u0631\u0627 \u067e\u06cc\u06a9\u0631\u0628\u0646\u062f\u06cc \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0647\u0645\u0647 \u067e\u0631\u0648\u0698\u0647 \u0647\u0627\u06cc Next.js \u062f\u0627\u0631\u0627\u06cc \u06cc\u06a9 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0647\u0633\u062a\u0646\u062f <code>\/pages<\/code> \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc\u060c \u06a9\u0647 \u062e\u0627\u0646\u0647 \u062a\u0645\u0627\u0645 \u0627\u062c\u0632\u0627\u06cc React \u0627\u0633\u062a \u06a9\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f.  \u0628\u0631\u0627\u06cc \u0647\u0631 \u0645\u0624\u0644\u0641\u0647 &#8211; \u06cc\u06a9 \u0631\u0648\u062a\u0631 \u0628\u0647 a page \u0645\u0633\u062a\u0642\u0631 \u0631\u0648\u06cc \u0622\u0646 \u062c\u0632\u0621<\/p>\n<blockquote>\n<p>\u06cc\u06a9 \u062c\u0632\u0621 React <strong>\u0627\u0633\u062a<\/strong> \u0622 page \u062f\u0631 \u0686\u0634\u0645\u0627\u0646 Next\u060c \u0648 \u0628\u0647 \u0637\u0648\u0631 \u062e\u0648\u062f\u06a9\u0627\u0631 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u0634\u0648\u062f \u0631\u0648\u06cc \u0645\u0633\u06cc\u0631 \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u0646\u0627\u0645 \u0641\u0627\u06cc\u0644 \u0622\u0646<\/p>\n<\/blockquote>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0641\u0631\u0636 \u06a9\u0646\u06cc\u062f \u0645\u0627 \u06cc\u06a9 \u062c\u0632\u0621 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645\u060c <code>contact.js<\/code>\u060c \u062f\u0631 \u062f\u0627\u062e\u0644 <code>\/pages<\/code> \u0641\u0647\u0631\u0633\u062a \u0631\u0627\u0647\u0646\u0645\u0627:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> Contact = <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>&gt;<\/span>\n            Contact\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> Contact\n<\/code><\/pre>\n<p>\u0631\u0648\u062a\u0631 \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u0633\u06cc\u0633\u062a\u0645 \u0641\u0627\u06cc\u0644 \u06a9\u0647 Next.js \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u06a9\u0646\u062f\u060c \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0645\u06cc\u200c\u06a9\u0646\u062f page \u0642\u0627\u0628\u0644 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0631 \u0632\u06cc\u0631 <code>\/contact<\/code> \u0645\u0633\u06cc\u0631!  \u062a\u0646\u0647\u0627 \u0627\u0633\u062a\u062b\u0646\u0627\u0621 \u0627\u06cc\u0646 \u0642\u0627\u0639\u062f\u0647 \u0627\u0633\u062a <code>index.js<\/code> page\u060c \u06a9\u0647 \u062f\u0631 \u0632\u06cc\u0631 \u0642\u0631\u0627\u0631 \u0646\u062f\u0627\u0631\u062f <code>\/index<\/code> \u0645\u0633\u06cc\u0631\u060c \u0628\u0644\u06a9\u0647 \u062f\u0631 \u0622\u0646 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u0634\u0648\u062f <code>\/<\/code>.<\/p>\n<p>\u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646\u060c \u0634\u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f <em>\u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0644\u0627\u0646\u0647<\/em> \u0628\u0627 Next.js\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0634\u0645\u0627 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f a \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f <code>\/weather\/berlin<\/code> \u0628\u0647 \u0635\u0648\u0631\u062a \u067e\u0648\u06cc\u0627 \u0628\u0627 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 <code>\/weather<\/code> \u067e\u0648\u0634\u0647\u060c \u0648 \u067e\u0648\u06cc\u0627 <code>(city).js<\/code> \u062c\u0632\u0621 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 page.<\/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> \u0628\u0631\u0627\u06cc \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u067e\u0648\u06cc\u0627\u060c \u0628\u0627\u06cc\u062f <em>\u0646\u0627\u0645<\/em> \u0641\u0627\u06cc\u0644 \u062f\u0631 \u0645\u062c\u0645\u0648\u0639\u0647 \u0627\u06cc \u0627\u0632 \u067e\u0631\u0627\u0646\u062a\u0632 \u0645\u0631\u0628\u0639.  \u0628\u062f\u0648\u0646 \u0622\u0646\u0647\u0627\u060c \u06cc\u06a9 \u0631\u0634\u062a\u0647 \u062a\u062d\u062a \u0627\u0644\u0644\u0641\u0638\u06cc \u062b\u0627\u0628\u062a \u0627\u0633\u062a \u0648 \u0628\u0647 \u0627\u06cc\u0646 \u062a\u0631\u062a\u06cc\u0628 \u062a\u062c\u0632\u06cc\u0647 \u0645\u06cc \u0634\u0648\u062f. <code>city.js<\/code> \u062d\u0644 \u062e\u0648\u0627\u0647\u062f \u06a9\u0631\u062f \u0628\u0647 <code>\/weather\/city<\/code> \u0645\u0633\u06cc\u0631\u060c \u0648 \u0628\u0631\u0627\u06cc \u0647\u06cc\u0686 \u0686\u06cc\u0632 \u062f\u06cc\u06af\u0631\u06cc \u0645\u0637\u0627\u0628\u0642\u062a \u0646\u062f\u0627\u0631\u062f.  \u0627\u0632 \u0633\u0648\u06cc \u062f\u06cc\u06af\u0631 <code>(city.js)<\/code> \u0628\u0631\u0627\u06cc <code>\/weather\/berlin<\/code>\u060c <code>\/weather\/london<\/code>\u060c <code>\/weather\/lagos<\/code>\u060c \u0648 \u063a\u06cc\u0631\u0647.<\/p>\n<\/p><\/div><\/div><\/div>\n<h4 id=\"thelinkcomponent\">\u0627\u06cc\u0646 <em><\u067e\u06cc\u0648\u0646\u062f><\/em> \u062c\u0632\u0621<\/h4>\n<p>\u0627\u06cc\u0646 <code>&lt;Link&gt;<\/code> \u062c\u0632\u0621 \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0631\u0627\u06cc \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0628\u06cc\u0646 \u0635\u0641\u062d\u0627\u062a \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0634\u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f.  \u0628\u0627 \u0641\u0631\u0636 \u067e\u0631\u0648\u0698\u0647 \u0645\u0627 page \u0633\u0627\u062e\u062a\u0627\u0631 \u062f\u0627\u0631\u0627\u06cc \u0686\u0646\u062f\u06cc\u0646 \u0635\u0641\u062d\u0647 \u062f\u0631 \u0632\u06cc\u0631 \u0627\u0633\u062a <code>\/pages<\/code> \u0641\u0647\u0631\u0633\u062a \u0631\u0627\u0647\u0646\u0645\u0627:<\/p>\n<pre><code class=\"hljs\">- pages\n  - index.js\n  - weather.js\n  - contact.js\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 <code>&lt;Link&gt;<\/code> \u0627\u062c\u0632\u0627\u0621 <code>href<\/code> \u0627\u0632 \u0648\u06cc\u0698\u06af\u06cc \u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0631\u0627\u06cc \u0627\u0634\u0627\u0631\u0647 \u0628\u0647 \u0645\u0633\u06cc\u0631 \u0646\u0633\u0628\u06cc \u0647\u0631 \u06a9\u062f\u0627\u0645 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f page\u060c \u0628\u0627 \u0634\u0631\u0648\u0639 \u062f\u0631 <code>\/pages<\/code> \u0641\u0647\u0631\u0633\u062a \u0631\u0627\u0647\u0646\u0645\u0627:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> Link <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"next\/link\"<\/span>;\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">Home<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n  <span class=\"hljs-keyword\">return<\/span> (\n    <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Link<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"\/\"<\/span>&gt;<\/span>Home<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">Link<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Link<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"\/weather\"<\/span>&gt;<\/span>Weather<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">Link<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Link<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"\/contact\"<\/span>&gt;<\/span>Contact<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">Link<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\n  )\n}\n<\/code><\/pre>\n<p>\u0628\u0647 \u0637\u0648\u0631 \u0637\u0628\u06cc\u0639\u06cc\u060c \u0627\u06af\u0631 \u06cc\u06a9 \u0633\u0644\u0633\u0644\u0647 \u0645\u0631\u0627\u062a\u0628 \u062a\u0648 \u062f\u0631 \u062a\u0648 \u0627\u0632 \u0641\u0627\u06cc\u0644 \u0647\u0627 \u062f\u0627\u0631\u06cc\u062f\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0647 \u0635\u0641\u062d\u0627\u062a \u062a\u0648\u062f\u0631\u062a\u0648 \u0646\u06cc\u0632 \u0644\u06cc\u0646\u06a9 \u062f\u0647\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\">- pages\n  - weather\n    - (city).js\n<\/code><\/pre>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> Link <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"next\/link\"<\/span>;\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">Weather<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n  <span class=\"hljs-keyword\">return<\/span> (\n    <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Link<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"\/weather\/berlin\"<\/span>&gt;<\/span>Berlin<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">Link<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Link<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"\/weather\/london\"<\/span>&gt;<\/span>London<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">Link<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Link<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"\/weather\/lagos\"<\/span>&gt;<\/span>Lagos<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">Link<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\n  )\n}\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 <code>&lt;Link&gt;<\/code> \u062c\u0632\u0621 \u0646\u06cc\u0632 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f <em>\u067e\u06cc\u0634 \u0648\u0627\u06a9\u0634\u06cc<\/em> \u0635\u0641\u062d\u0627\u062a!  \u06cc\u06a9 \u0628\u0627\u0631 \u062f\u0631 page \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a\u060c \u0648 \u0686\u0646\u062f\u06cc\u0646 \u0644\u06cc\u0646\u06a9 \u0628\u0647 \u0635\u0641\u062d\u0627\u062a \u062f\u06cc\u06af\u0631 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f &#8211; \u0627\u06af\u0631 \u0645\u06cc \u062f\u0627\u0646\u06cc\u062f \u06a9\u0647 \u0645\u0634\u062e\u0635 \u0627\u0633\u062a page \u0628\u0627\u06cc\u062f \u0627\u063a\u0644\u0628 \u0628\u0627\u0632\u062f\u06cc\u062f \u0634\u0648\u062f\u060c \u06cc\u0627 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u0645 \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u0645 \u06a9\u0647 page \u062f\u0631 \u0627\u0633\u0631\u0639 \u0648\u0642\u062a \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0645\u06cc \u0634\u0648\u062f (\u0628\u062f\u0648\u0646 \u062a\u0623\u062b\u06cc\u0631 \u0627\u0648\u0644\u06cc\u0647 page)\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0642\u0628\u0644 \u0648\u0627\u06a9\u0634\u06cc \u06a9\u0646\u06cc\u062f page \u0645\u0631\u062a\u0628\u0637 \u0628\u0627 \u0627\u0644\u0641 <code>&lt;Link&gt;<\/code> \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0627\u0646\u062a\u0642\u0627\u0644 \u0633\u0631\u06cc\u0639\u062a\u0631 \u0648 \u0631\u0648\u0627\u0646\u062a\u0631 \u0627\u0646\u062c\u0627\u0645 \u0634\u0648\u062f!<\/p>\n<blockquote>\n<p>\u062f\u0631 \u0648\u0627\u0642\u0639 Next.js \u0628\u0647 \u0635\u0648\u0631\u062a \u067e\u06cc\u0634 \u0641\u0631\u0636 \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0627\u062a \u0631\u0627 \u0627\u0632 \u067e\u06cc\u0634 \u0648\u0627\u06a9\u0634\u06cc \u0645\u06cc \u06a9\u0646\u062f.  \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u0645\u0646\u0638\u0648\u0631\u060c \u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0633\u0631\u0639\u062a \u0627\u0646\u062a\u0642\u0627\u0644 \u0628\u0647 \u06cc\u06a9 \u0645\u0639\u06cc\u0646 \u0631\u0627 \u0627\u0641\u0632\u0627\u06cc\u0634 \u062f\u0647\u06cc\u062f page\u060c \u0634\u0645\u0627 \u062a\u0646\u0638\u06cc\u0645 \u06a9\u0646\u06cc\u062f <code>prefetch<\/code> \u0646\u0633\u0628\u062a \u0628\u0647 <code>false<\/code> \u0628\u0631\u0627\u06cc \u0635\u0641\u062d\u0627\u062a \u062f\u06cc\u06af\u0631<\/p>\n<\/blockquote>\n<p>\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0645\u06cc \u062a\u0648\u0627\u0646 \u062a\u0635\u0648\u0631 \u06a9\u0631\u062f \u06a9\u0647 \u062f\u0631 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0648\u0627\u0634\u0646\u0627\u0633\u06cc\u060c \u0627\u0641\u0631\u0627\u062f \u0628\u06cc\u0634\u062a\u0631 \u0628\u0647 <code>\/weather<\/code> \u0645\u0633\u06cc\u0631 \u0627\u0632 \u062e\u0627\u0646\u0647 page\u060c \u0628\u0647 \u062c\u0627\u06cc <code>\/about<\/code>.  \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u0648\u0627\u06a9\u0634\u06cc \u0627\u0632 \u0642\u0628\u0644 \u0648\u062c\u0648\u062f \u0646\u062f\u0627\u0631\u062f <code>about.js<\/code> page\/component\u060c \u0632\u06cc\u0631\u0627 \u0633\u0631\u0648\u0631 \u0631\u0627 \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u0628\u0627\u0631 \u0628\u06cc\u0634\u062a\u0631 \u0645\u06cc \u06a9\u0646\u06cc\u062f page \u0628\u0647 \u0627\u062d\u062a\u0645\u0627\u0644 \u0632\u06cc\u0627\u062f \u0631\u0648\u06cc \u0622\u0646 \u06a9\u0644\u06cc\u06a9 \u0646\u0645\u06cc \u0634\u0648\u062f.  \u0627\u0632 \u0633\u0648\u06cc \u062f\u06cc\u06af\u0631 &#8211; <code>weather.js<\/code> \u0628\u0647 \u0627\u062d\u062a\u0645\u0627\u0644 \u0632\u06cc\u0627\u062f \u0645\u0633\u06cc\u0631 \u0628\u0639\u062f\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0627\u0641\u0631\u0627\u062f \u0628\u0627\u0632\u062f\u06cc\u062f \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0627 \u0648\u0627\u06a9\u0634\u06cc \u0627\u0632 \u0642\u0628\u0644 \u0622\u0646\u060c \u0645\u062f\u062a\u06cc \u0631\u0627 \u062f\u0631 \u0645\u0631\u062d\u0644\u0647 \u0627\u0646\u062a\u0642\u0627\u0644 \u0627\u0632 \u0628\u06cc\u0646 \u0628\u0628\u0631\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> Link <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"next\/link\"<\/span>;\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">Home<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n  <span class=\"hljs-keyword\">return<\/span> (\n    <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Link<\/span> <span class=\"hljs-attr\">prefetch<\/span>=<span class=\"hljs-string\">true<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"\/weather\"<\/span>&gt;<\/span>Weather<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">Link<\/span>&gt;<\/span>\n      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Link<\/span> <span class=\"hljs-attr\">prefetch<\/span>=<span class=\"hljs-string\">false<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"\/about\"<\/span>&gt;<\/span>About Us<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">Link<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\n  )\n}\n<\/code><\/pre>\n<p>\u0628\u0631\u062e\u06cc \u0627\u0632 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0639\u0628\u0627\u0631\u062a\u0646\u062f \u0627\u0632 <code>scroll<\/code> \u0648\u06cc\u0698\u06af\u06cc (\u06a9\u0647 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0628\u0647 <code>true<\/code>) \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u0628\u0647 \u0628\u0627\u0644\u0627\u06cc \u0635\u0641\u062d\u0647 \u0647\u062f\u0627\u06cc\u062a \u0645\u06cc \u06a9\u0646\u062f page \u0648\u0642\u062a\u06cc \u0622\u0646\u0647\u0627 \u062e\u0648\u062f \u0631\u0627 \u0628\u0627 \u06cc\u06a9 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631 \u0645\u06cc \u062f\u0647\u0646\u062f <code>&lt;Link&gt;<\/code>.  \u0627\u06cc\u0646 \u06cc\u06a9 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636 \u0628\u0633\u06cc\u0627\u0631 \u0645\u0639\u0642\u0648\u0644 \u0627\u0633\u062a\u060c \u0627\u06af\u0631\u0686\u0647 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u062e\u0648\u0627\u0647\u06cc\u062f \u0622\u0646 \u0631\u0627 \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u0627\u062b\u0631 \u062e\u0627\u0635\u200c\u062a\u0631 \u06a9\u0647 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u0628\u0647 \u062f\u0633\u062a \u0622\u0648\u0631\u06cc\u062f\u060c \u062e\u0627\u0645\u0648\u0634 \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u06cc\u06a9\u06cc \u062f\u06cc\u06af\u0631 \u0627\u0632 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc \u0642\u0627\u0628\u0644 \u062a\u0648\u062c\u0647 \u0627\u0633\u062a <code>replace<\/code> \u0648\u06cc\u0698\u06af\u06cc\u060c \u06a9\u0647 \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0628\u0647 <code>false<\/code>.  \u0627\u06af\u0631 \u062a\u0646\u0638\u06cc\u0645 \u0634\u0648\u062f <code>true<\/code>\u060c \u0628\u0647 \u062c\u0627\u06cc \u0641\u0634\u0627\u0631 \u062f\u0627\u062f\u0646 \u06cc\u06a9 \u0648\u0631\u0648\u062f\u06cc \u062c\u062f\u06cc\u062f\u060c \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0647 \u06cc\u06a9 \u062c\u062f\u06cc\u062f \u067e\u06cc\u0645\u0627\u06cc\u0634 \u0645\u06cc \u06a9\u0646\u06cc\u062f\u060c \u0622\u062e\u0631\u06cc\u0646 \u0648\u0631\u0648\u062f\u06cc \u062f\u0631 \u067e\u0634\u062a\u0647 \u062a\u0627\u0631\u06cc\u062e \u0631\u0627 \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u0645\u06cc \u06a9\u0646\u062f. page\/\u0645\u0633\u06cc\u0631 \u0628\u0627 \u0627\u0644\u0641 <code>&lt;Link&gt;<\/code>.<\/p>\n<h3 id=\"prerenderingpages\"><span class=\"ez-toc-section\" id=\"%d8%b5%d9%81%d8%ad%d8%a7%d8%aa_%d9%be%db%8c%d8%b4_%d8%b1%d9%86%d8%af%d8%b1\"><\/span>\u0635\u0641\u062d\u0627\u062a \u067e\u06cc\u0634 \u0631\u0646\u062f\u0631<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0635\u062d\u0628\u062a \u0627\u0632 \u0648\u0627\u06a9\u0634\u06cc \u0648 \u067e\u06cc\u0634 \u0631\u0646\u062f\u0631 \u06a9\u0631\u062f\u0646 \u0635\u0641\u062d\u0627\u062a \u0634\u062f &#8211; \u0627\u06cc\u0646 \u0648\u06cc\u0698\u06af\u06cc Next.js \u06cc\u06a9\u06cc \u0627\u0632 \u0645\u0631\u062a\u0628\u0637\u200c\u062a\u0631 \u0627\u0633\u062a.  \u0645\u062c\u062f\u062f\u0627\u064b\u060c \u0628\u0647\u200c\u0637\u0648\u0631 \u067e\u06cc\u0634\u200c\u0641\u0631\u0636\u060c Next.js \u062a\u0645\u0627\u0645 \u0635\u0641\u062d\u0627\u062a\u06cc \u0631\u0627 \u06a9\u0647 \u0628\u0647 \u0622\u0646\u200c\u0647\u0627 \u067e\u06cc\u0648\u0646\u062f \u0645\u06cc\u200c\u062f\u0647\u06cc\u062f\u060c \u0627\u0632 \u0642\u0628\u0644 \u0648\u0627\u06a9\u0634\u06cc \u0645\u06cc\u200c\u06a9\u0646\u062f \u0648 \u0627\u0645\u06a9\u0627\u0646 \u0627\u0646\u062a\u0642\u0627\u0644 \u0633\u0631\u06cc\u0639 \u0648 \u0631\u0648\u0627\u0646 \u0628\u06cc\u0646 \u0622\u0646\u0647\u0627 \u0631\u0627 \u0641\u0631\u0627\u0647\u0645 \u0645\u06cc\u200c\u06a9\u0646\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0647\u0631 page\u060c \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u06cc\u06a9\u06cc \u0631\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u06cc\u062f <strong><em>\u0631\u0646\u062f\u0631 \u0633\u0645\u062a \u0633\u0631\u0648\u0631<\/em><\/strong>  \u06cc\u0627 <strong><em>\u062a\u0648\u0644\u06cc\u062f \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9<\/em><\/strong>  \u0648 \u0627\u06cc\u0646\u06a9\u0647 \u06a9\u062f\u0627\u0645 \u062a\u06a9\u0646\u06cc\u06a9 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f \u0628\u0633\u062a\u06af\u06cc \u062f\u0627\u0631\u062f \u0631\u0648\u06cc \u062a\u0648\u0627\u0628\u0639\u06cc \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0648\u0627\u06a9\u0634\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u062f.  \u0634\u0645\u0627 \u0645\u062c\u0628\u0648\u0631 \u0646\u06cc\u0633\u062a\u06cc\u062f \u0628\u0647 \u06cc\u06a9\u06cc \u0627\u0632 \u0627\u06cc\u0646 \u062a\u06a9\u0646\u06cc\u06a9 \u0647\u0627 \u0628\u0631\u0627\u06cc \u06a9\u0644 \u0628\u0631\u0646\u0627\u0645\u0647 \u067e\u0627\u06cc\u0628\u0646\u062f \u0628\u0627\u0634\u06cc\u062f!<\/p>\n<blockquote>\n<p>\u0627\u0646\u062a\u062e\u0627\u0628 \u0628\u06cc\u0646 SSR \u0648 SG \u06cc\u06a9 \u0633\u0648\u0627\u0644 \u0627\u0633\u062a \u06a9\u0647 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0628\u0627\u0631 \u0631\u0627 \u06a9\u062c\u0627 \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u062f \u0648 <strong>\u0647\u0631 \u062f\u0648<\/strong> \u062a\u06a9\u0646\u06cc\u06a9\u200c\u0647\u0627 \u0635\u0641\u062d\u0627\u062a \u0631\u0627 \u0627\u0632 \u0642\u0628\u0644 \u0627\u062c\u0631\u0627 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f\u060c \u0641\u0642\u0637 \u0628\u0647 \u0631\u0648\u0634\u06cc \u0645\u062a\u0641\u0627\u0648\u062a.<\/p>\n<\/blockquote>\n<p>\u0627\u06af\u0631 \u0635\u0641\u062d\u0627\u062a \u062e\u0648\u062f \u0631\u0627 \u0631\u0646\u062f\u0631 \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u067e\u0627\u06cc\u0627\u0646 \u0633\u0631\u0648\u0631\u060c \u0622\u0646\u0647\u0627 \u0627\u0631\u0627\u0626\u0647 \u062e\u0648\u0627\u0647\u0646\u062f \u0634\u062f \u0631\u0648\u06cc \u0647\u0631 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u060c \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u0645\u0646\u0627\u0628\u0639 \u0633\u0631\u0648\u0631 \u0634\u0645\u0627\u060c \u0648 \u0628\u0631\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0646\u0647\u0627\u06cc\u06cc \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u0634\u0648\u062f.  \u0627\u06af\u0631 \u0628\u0647 \u0635\u0648\u0631\u062a \u0627\u06cc\u0633\u062a\u0627 \u06cc\u06a9 \u0631\u0627 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f page\u060c \u06cc\u06a9 \u0628\u0627\u0631 \u062a\u0648\u0644\u06cc\u062f \u0645\u06cc \u0634\u0648\u062f \u0648 \u067e\u0633 \u0627\u0632 \u0632\u0645\u0627\u0646 \u0633\u0627\u062e\u062a \u0642\u0627\u0628\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f \u0627\u0633\u062a.<\/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> \u0628\u0647 \u0637\u0648\u0631 \u06a9\u0644\u06cc\u060c \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <strong><em>\u062a\u0648\u0644\u06cc\u062f \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9<\/em><\/strong>  \u0647\u0631 \u0632\u0645\u0627\u0646 \u06a9\u0647 \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0646\u0628\u0627\u0634\u062f <strong><em>\u0631\u0646\u062f\u0631 \u0633\u0645\u062a \u0633\u0631\u0648\u0631<\/em><\/strong>  \u0627\u0632 \u0622\u0646\u062c\u0627 \u06a9\u0647 page \u0633\u067e\u0633 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u062d\u0627\u0641\u0638\u0647 \u067e\u0646\u0647\u0627\u0646 \u0648 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u062c\u062f\u062f\u060c \u0635\u0631\u0641\u0647 \u062c\u0648\u06cc\u06cc \u062f\u0631 \u0645\u062d\u0627\u0633\u0628\u0627\u062a \u0627\u0631\u0632\u0634\u0645\u0646\u062f.  \u0647\u0631 \u0632\u0645\u0627\u0646 \u06a9\u0647 \u0627\u062c\u0632\u0627 \u0631\u0648\u06cc \u0635\u0641\u062d\u0627\u062a \u0645\u06a9\u0631\u0631 \u0647\u0633\u062a\u0646\u062f\u060c <em>\u0631\u0646\u062f\u0631 \u0633\u0645\u062a \u0633\u0631\u0648\u0631<\/em> \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u0627\u0633\u062a \u0648 page \u062f\u0631 \u0635\u0648\u0631\u062a \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0628\u0627 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062c\u062f\u06cc\u062f \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u0634\u0648\u062f (\u06a9\u0647 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0622\u0646\u0647\u0627 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0633\u062a\u06af\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f \u0631\u0648\u06cc \u062e\u0648\u062f \u062f\u0631\u062e\u0648\u0627\u0633\u062a).<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u062a\u0635\u0645\u06cc\u0645 \u0628\u06af\u06cc\u0631\u06cc\u062f \u0628\u0647 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0635\u0641\u062d\u0627\u062a \u06cc\u0627 \u0639\u0646\u0627\u0635\u0631 \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u0631\u0648\u06cc \u0631\u0627 page \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0627\u0631\u0627\u0626\u0647 \u0634\u0648\u062f <strong><em>\u0631\u0646\u062f\u0631 \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc<\/em><\/strong>  \u06a9\u0647 \u0628\u0627\u0631 \u0631\u0627 \u0642\u0631\u0627\u0631 \u0645\u06cc \u062f\u0647\u062f \u0631\u0648\u06cc \u0645\u0627\u0634\u06cc\u0646 \u06a9\u0627\u0631\u0628\u0631 \u0646\u0647\u0627\u06cc\u06cc\u060c \u0627\u0645\u0627 \u0634\u0645\u0627 \u0647\u06cc\u0686 \u062a\u0636\u0645\u06cc\u0646\u06cc \u06cc\u0627 \u06a9\u0646\u062a\u0631\u0644\u06cc \u0628\u0631 \u0645\u0646\u0627\u0628\u0639 \u0622\u0646\u0647\u0627 \u0646\u062f\u0627\u0631\u06cc\u062f\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u0639\u0645\u0648\u0644\u0627\u064b \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u062f \u0627\u0632 \u0647\u0631 \u06af\u0648\u0646\u0647 \u0645\u062d\u0627\u0633\u0628\u0627\u062a \u0641\u0634\u0631\u062f\u0647 \u0627\u062c\u062a\u0646\u0627\u0628 \u06a9\u0646\u06cc\u062f. \u0631\u0648\u06cc \u067e\u0627\u06cc\u0627\u0646 \u0622\u0646\u0647\u0627<\/p>\n<blockquote>\n<p>\u067e\u06cc\u0634 \u0631\u0646\u062f\u0631 \u062f\u0631 \u0639\u0645\u0644 \u0645\u0633\u062a\u0644\u0632\u0645 \u0686\u0647 \u0686\u06cc\u0632\u06cc \u0627\u0633\u062a\u061f<\/p>\n<\/blockquote>\n<p>\u0627\u06cc\u0646 \u0686\u06af\u0648\u0646\u0647 \u0628\u0631 \u06a9\u0627\u0631\u0628\u0631 \u0646\u0647\u0627\u06cc\u06cc \u062a\u0623\u062b\u06cc\u0631 \u0645\u06cc \u06af\u0630\u0627\u0631\u062f \u0648 \u0686\u06af\u0648\u0646\u0647 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0633\u0627\u062f\u0647 React \u0631\u0627 \u0628\u0647\u0628\u0648\u062f \u0645\u06cc \u0628\u062e\u0634\u062f\u061f  \u067e\u06cc\u0634 \u0631\u0646\u062f\u0631 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u062a\u0627 \u0622\u0646 \u0631\u0627 \u0628\u0628\u06cc\u0646\u062f page \u062d\u062a\u06cc \u0642\u0628\u0644 \u0627\u0632 \u0627\u06cc\u0646\u06a9\u0647 \u06a9\u062f \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0634\u0648\u062f.  \u0632\u0645\u0627\u0646 \u0628\u0633\u06cc\u0627\u0631 \u06a9\u0645\u06cc \u0637\u0648\u0644 \u0645\u06cc \u06a9\u0634\u062f \u062a\u0627 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0634\u0648\u062f &#8211; \u0627\u0645\u0627 \u0627\u06cc\u0646\u0647\u0627 <em>\u0645\u06cc\u0644\u06cc \u062b\u0627\u0646\u06cc\u0647<\/em> \u0646\u0627\u062e\u0648\u0627\u0633\u062a\u0647 \u0628\u0631 \u062f\u0631\u06a9 \u0645\u0627 \u062a\u0623\u062b\u06cc\u0631 \u0645\u06cc \u06af\u0630\u0627\u0631\u062f.  \u062d\u062a\u06cc \u0627\u06af\u0631 page \u0628\u0647 \u0635\u0648\u0631\u062a\u06cc \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f \u06a9\u0647 \u067e\u0633 \u0627\u0632 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0647\u0645\u0647 \u0645\u0624\u0644\u0641\u0647 \u0647\u0627 \u062a\u0648\u0633\u0637 \u06a9\u0627\u0631\u0628\u0631 \u0645\u0634\u0627\u0647\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f &#8211; \u0647\u06cc\u0686 \u06a9\u062f\u0627\u0645 \u0647\u0646\u0648\u0632 \u06a9\u0627\u0631 \u0646\u0645\u06cc \u06a9\u0646\u0646\u062f.<\/p>\n<p>\u0641\u0642\u0637 \u06cc\u06a9 \u0628\u0627\u0631 \u0627\u0633\u062a page \u0646\u0634\u0627\u0646 \u062f\u0627\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u06a9\u0647 \u0627\u062c\u0632\u0627 \u062f\u0631 \u062d\u0627\u0644 \u067e\u0631\u062f\u0627\u0632\u0634 \u0648 \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0647\u0633\u062a\u0646\u062f \u062a\u0627 \u0628\u0647 \u0627\u062c\u0632\u0627\u06cc \u062a\u0639\u0627\u0645\u0644\u06cc \u062a\u0628\u062f\u06cc\u0644 \u0634\u0648\u0646\u062f.  \u0627\u06cc\u0646 process \u0646\u0627\u0645\u06cc\u062f\u0647 \u0645\u06cc\u0634\u0648\u062f <strong><em>\u0647\u06cc\u062f\u0631\u0627\u062a\u0627\u0633\u06cc\u0648\u0646<\/em><\/strong>.<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/guide-to-getting-started-with-nextjs-create-a-nextjs-app-1.png\" alt=\"\u067e\u06cc\u0634 \u0631\u0646\u062f\u0631 \u0628\u0627 Next.js\" title=\"\"><\/p>\n<p>\u0628\u062f\u0648\u0646 Next.js\u060c page \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0645\u06cc \u0634\u0648\u062f \u0648 \u0627\u062c\u0632\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0627\u0648\u0644\u06cc\u0647 \u0633\u0627\u0632\u06cc \u0647\u0633\u062a\u0646\u062f \u062e\u0627\u0644\u06cc \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f.<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/guide-to-getting-started-with-nextjs-create-a-nextjs-app-2.png\" alt=\"\u0631\u0646\u062f\u0631 \u0628\u0627 React.js\" title=\"\"><\/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>\u0627\u0632 \u0622\u0646\u062c\u0627\u06cc\u06cc \u06a9\u0647 \u067e\u06cc\u0634 \u0631\u0646\u062f\u0631 \u06cc\u06a9 \u0627\u0633\u062a <em>\u0627\u0646\u062a\u06af\u0631\u0627\u0644<\/em> \u0628\u062e\u0634\u06cc \u0627\u0632 Next.js\u060c \u0628\u0631\u062e\u06cc \u0627\u0632 \u062a\u0648\u0627\u0628\u0639 \u0631\u0627 \u06a9\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0631\u0627\u06cc \u062a\u0633\u0647\u06cc\u0644 \u067e\u06cc\u0634 \u0631\u0646\u062f\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f\u060c \u0627\u0632 \u0637\u0631\u06cc\u0642 <strong>SSR<\/strong> \u0648 <strong>SG<\/strong>.<\/p>\n<\/p><\/div><\/div><\/div>\n<h4 id=\"fetchingserversidedatagetserversideprops\">\u0648\u0627\u06a9\u0634\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0633\u0645\u062a \u0633\u0631\u0648\u0631 &#8211; <em>getServerSideProps()<\/em><\/h4>\n<p>\u0627\u06cc\u0646 <code>getServerSideProps()<\/code> \u062a\u0627\u0628\u0639 \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0639\u0645\u0644\u06cc\u0627\u062a \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u0633\u0631\u0648\u0631 \u0645\u0627\u0646\u0646\u062f \u0648\u0627\u06a9\u0634\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627 \u0627\u0632 \u06cc\u06a9 API \u062e\u0627\u0631\u062c\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u0628\u0627\u0632 \u0647\u0645\u060c \u0634\u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0647\u0631 \u0632\u0645\u0627\u0646 \u06a9\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627 SSR \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u062f \u0631\u0648\u06cc \u0631\u0627 page \u0628\u0647 \u0633\u0631\u0639\u062a \u062a\u063a\u06cc\u06cc\u0631 \u0645\u06cc \u06a9\u0646\u062f\u060c \u0648 \u0630\u062e\u06cc\u0631\u0647 \u0622\u0646 \u0645\u0646\u0637\u0642\u06cc \u0646\u06cc\u0633\u062a.  \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u06cc\u06a9 API \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0627 \u0642\u06cc\u0645\u062a\u200c\u0647\u0627\u06cc \u0633\u0647\u0627\u0645 \u06cc\u0627 \u0632\u0645\u0627\u0646 \u0628\u0647\u200c\u0631\u0648\u0632 \u0634\u062f\u0647 \u067e\u0627\u0633\u062e \u062f\u0647\u062f \u0631\u0648\u06cc \u06cc\u06a9 \u0633\u0627\u0639\u062a \u062f\u0631 \u0647\u0631 \u062b\u0627\u0646\u06cc\u0647\u060c \u0648 \u0631\u0648\u06cc \u0647\u0631 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u06a9\u0627\u0631\u0628\u0631 &#8211; \u0627\u06cc\u0646\u0647\u0627 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0631\u0648\u0632 \u0628\u0627\u0634\u0646\u062f.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0645\u062b\u0627\u0644\u06cc \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06a9\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u06cc \u0631\u0627 \u0628\u0647 \u06cc\u06a9 API \u0646\u0645\u0648\u0646\u0647 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f \u0648 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u0634\u062f\u0647 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u067e\u0634\u062a\u0648\u0627\u0646\u0647 \u0628\u0647 \u0645\u0627 \u0627\u0631\u0633\u0627\u0644 \u0645\u06cc \u06a9\u0646\u062f page \u062c\u0632\u0621:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> Weather = <span class=\"hljs-function\">(<span class=\"hljs-params\">{temperature}<\/span>) =&gt;<\/span> {\n<span class=\"hljs-comment\">\/\/ display temperature<\/span>\n\n}\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> Weather\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">async<\/span> <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">getServerSideProps<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n  <span class=\"hljs-keyword\">const<\/span> res = fetch(<span class=\"hljs-string\">'http:\/\/example.com\/api'<\/span>)\n  ...\n  <span class=\"hljs-keyword\">const<\/span> temperature = res.temperature\n  <span class=\"hljs-keyword\">return<\/span> {\n    <span class=\"hljs-attr\">props<\/span>: {temperature},\n  }\n}\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 <code>getServerSideProps()<\/code> \u0627\u0644\u0641 \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u062f <code>context<\/code> \u0634\u06cc \u06a9\u0647 \u062d\u0627\u0648\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u0633\u0631\u0648\u0631 \u0645\u0627\u0646\u0646\u062f \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0647\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a\u06cc\u060c \u067e\u0627\u0633\u062e \u0647\u0627\u06cc \u0633\u0631\u0648\u0631\u060c \u067e\u0631\u0633 \u0648 \u062c\u0648\u0647\u0627 \u0627\u0633\u062a.  \u0627\u06cc\u0646 \u0628\u0633\u06cc\u0627\u0631 \u0645\u0647\u0645 \u0627\u0633\u062a\u060c \u0632\u06cc\u0631\u0627 \u062e\u0648\u062f \u0631\u0646\u062f\u0631 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0633\u062a\u06af\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f \u0631\u0648\u06cc \u0631\u0627 <code>context<\/code>.<\/p>\n<h4 id=\"staticgenerationpathsgetstaticpaths\">\u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u062a\u0648\u0644\u06cc\u062f \u0627\u06cc\u0633\u062a\u0627 &#8211; <em>getStaticPaths()<\/em><\/h4>\n<p>\u0645\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>getStaticPaths()<\/code> \u062a\u0627\u0628\u0639 \u0628\u0631\u0627\u06cc \u062a\u0639\u0631\u06cc\u0641 \u0644\u06cc\u0633\u062a\u06cc \u0627\u0632 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0635\u0648\u0631\u062a \u0627\u06cc\u0633\u062a\u0627 \u0628\u0631\u0627\u06cc \u06cc\u06a9 \u0645\u0633\u06cc\u0631 \u067e\u0648\u06cc\u0627 \u062a\u0648\u0644\u06cc\u062f \u0634\u0648\u0646\u062f.  \u0628\u06af\u0648 \u0645\u0627 \u06cc\u06a9 \u0645\u0633\u06cc\u0631 \u067e\u0648\u06cc\u0627 \u062f\u0627\u0631\u06cc\u0645 <code>pages\/weather\/(city).js<\/code> \u0648 \u0645\u0627 export \u0622 <code>getStaticPaths()<\/code> \u062f\u0631 \u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u0645\u0627\u0646\u0646\u062f \u0632\u06cc\u0631 \u0639\u0645\u0644 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">async<\/span> <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">getStaticPaths<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n  <span class=\"hljs-keyword\">return<\/span> {\n    <span class=\"hljs-attr\">paths<\/span>: ({ <span class=\"hljs-attr\">params<\/span>: { <span class=\"hljs-attr\">id<\/span>: <span class=\"hljs-string\">'paris'<\/span> } }, { <span class=\"hljs-attr\">params<\/span>: { <span class=\"hljs-attr\">id<\/span>: <span class=\"hljs-string\">'london'<\/span> } }),\n  };\n}\n<\/code><\/pre>\n<p>Next.js \u0628\u0647 \u0635\u0648\u0631\u062a \u062e\u0648\u062f\u06a9\u0627\u0631 \u062a\u0648\u0644\u06cc\u062f \u0645\u06cc \u0634\u0648\u062f <code>\/weather\/paris<\/code> \u0648 <code>\/weather\/london<\/code> \u0628\u0631\u0627\u06cc \u0645\u0627 \u062f\u0631 \u0632\u0645\u0627\u0646 \u0633\u0627\u062e\u062a<\/p>\n<h4 id=\"staticgenerationpropsgetstaticprops\">\u0644\u0648\u0627\u0632\u0645 \u062a\u0648\u0644\u06cc\u062f \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 &#8211; <em>getStaticProps()<\/em><\/h4>\n<p>\u0627\u06cc\u0646 <code>getStaticProps()<\/code> \u062a\u0627\u0628\u0639 \u0645\u0634\u0627\u0628\u0647 \u0627\u0633\u062a <code>getServerSideProps()<\/code> \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0639\u0646\u0627 \u06a9\u0647 \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0648\u0633\u0627\u06cc\u0644 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0631\u0648\u06cc \u0627\u0632 \u067e\u06cc\u0634 \u0631\u0646\u062f\u0631 \u0634\u062f\u0647 page.  \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0631\u062f\u060c props \u0628\u0647 \u0635\u0648\u0631\u062a \u0627\u06cc\u0633\u062a\u0627 \u062f\u0631 \u0632\u0645\u0627\u0646 \u0633\u0627\u062e\u062a \u062a\u0648\u0644\u06cc\u062f \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u0648 \u0628\u0639\u062f\u0627\u064b \u0628\u0631\u0627\u06cc \u0647\u0645\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a\u200c\u0647\u0627 \u0645\u062c\u062f\u062f\u0627\u064b \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f\u060c \u0628\u0647 \u062c\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u062f\u0631 \u0632\u0645\u0627\u0646 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0627\u0631\u0627\u0626\u0647 \u0634\u0648\u0646\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">async<\/span> <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">getStaticProps<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n\n  <span class=\"hljs-keyword\">const<\/span> res = <span class=\"hljs-keyword\">await<\/span> fetch(<span class=\"hljs-string\">'http:\/\/someapi\/toget\/cities'<\/span>)\n  ...\n  <span class=\"hljs-keyword\">const<\/span> cities = <span class=\"hljs-keyword\">await<\/span> res.json()\n  <span class=\"hljs-keyword\">return<\/span> {\n    <span class=\"hljs-attr\">props<\/span>: {\n      cities,\n    },\n  }\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> <code>getStaticPaths()<\/code>  \u0628\u0627 \u06a9\u0627\u0631 \u0646\u062e\u0648\u0627\u0647\u062f \u06a9\u0631\u062f <code>getServerSideProps()<\/code> &#8211; \u062f\u0631 \u0639\u0648\u0636\u060c \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f <code>getStaticProps()<\/code>.  \u0628\u0647\u062a\u0631 \u0627\u0633\u062a \u0627\u0632 \u0627\u06cc\u0646 \u062a\u0627\u0628\u0639 \u0641\u0642\u0637 \u0632\u0645\u0627\u0646\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f \u06a9\u0647 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u0632 \u0642\u0628\u0644 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u0628\u0647 \u0633\u0631\u0639\u062a \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u0645\u06cc\u200c\u0634\u0648\u0646\u062f \u06cc\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u0646\u062f \u0628\u0647 \u0635\u0648\u0631\u062a \u0639\u0645\u0648\u0645\u06cc \u0630\u062e\u06cc\u0631\u0647 \u0634\u0648\u0646\u062f.<\/p>\n<\/p><\/div><\/div><\/div>\n<h3 id=\"headseo\"><span class=\"ez-toc-section\" id=\"_%d8%b3%d8%a6%d9%88\"><\/span><em><\u0633\u0631\/><\/em> &#038; \u0633\u0626\u0648<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0627\u0632 \u0622\u0646\u062c\u0627 \u06a9\u0647 <em>\u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u062a\u06a9 \u0635\u0641\u062d\u0647 \u0627\u06cc<\/em> \u062e\u0632\u06cc\u062f\u0646 \u062a\u0648\u0633\u0637 \u0645\u0648\u062a\u0648\u0631\u0647\u0627\u06cc \u062c\u0633\u062a\u062c\u0648 \u062f\u0634\u0648\u0627\u0631 \u0627\u0633\u062a\u060c \u0628\u0647\u06cc\u0646\u0647 \u0633\u0627\u0632\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc React \u0628\u0631\u0627\u06cc \u0645\u0648\u062a\u0648\u0631\u0647\u0627\u06cc \u062c\u0633\u062a\u062c\u0648 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u062f\u0634\u0648\u0627\u0631 \u0628\u0627\u0634\u062f.  \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0631\u0646\u062f\u0631 \u0633\u0645\u062a \u0633\u0631\u0648\u0631 Next.js \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0648\u0636\u0648\u0639 \u0645\u06cc \u067e\u0631\u062f\u0627\u0632\u062f\u060c \u0641\u0631\u06cc\u0645 \u0648\u0631\u06a9 \u0634\u0627\u0645\u0644 \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc \u062e\u0627\u0635 \u0646\u06cc\u0632 \u0645\u06cc \u0634\u0648\u062f <code>&lt;Head \/&gt;<\/code> \u0645\u0648\u0644\u0641\u0647 \u0627\u06cc \u06a9\u0647 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0631\u062f\u0646 \u0639\u0646\u0627\u0635\u0631 \u0631\u0627 \u0628\u0647 \u0633\u0631 \u062e\u0648\u062f \u0622\u0633\u0627\u0646 \u0645\u06cc \u06a9\u0646\u062f page.<\/p>\n<p>\u062f\u0631 \u0646\u062a\u06cc\u062c\u0647\u060c \u0628\u0647 \u0631\u0648\u0632 \u0631\u0633\u0627\u0646\u06cc \u062a\u0646\u0638\u06cc\u0645\u0627\u062a SEO \u0635\u0641\u062d\u0627\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627\u0646\u0646\u062f \u0628\u0631\u0686\u0633\u0628 \u0639\u0646\u0648\u0627\u0646\u060c \u062a\u0648\u0636\u06cc\u062d\u0627\u062a \u0645\u062a\u0627 \u0648 \u0647\u0631 \u0639\u0646\u0635\u0631 \u062f\u06cc\u06af\u0631\u06cc \u06a9\u0647 \u062f\u0631 \u06cc\u06a9 HTML \u0627\u0633\u062a\u0627\u0646\u062f\u0627\u0631\u062f \u06af\u0646\u062c\u0627\u0646\u062f\u0647 \u0627\u06cc\u062f. <code>&lt;head&gt;<\/code> \u0628\u0631\u0686\u0633\u0628 \u0633\u0627\u062f\u0647 \u062a\u0631 \u0627\u0633\u062a:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> Head <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"next\/head\"<\/span>;\n\n<span class=\"hljs-keyword\">const<\/span> Contact = <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>&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\">title<\/span>&gt;<\/span>Contact<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">title<\/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\">\"description\"<\/span> <span class=\"hljs-attr\">content<\/span>=<span class=\"hljs-string\">\"Welcome to our contact page!\"<\/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\">div<\/span>&gt;<\/span><\/span>\n  );\n};\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> Contact;\n<\/code><\/pre>\n<h2 id=\"creatingapirouteswithnextjs\"><span class=\"ez-toc-section\" id=\"%d8%a7%db%8c%d8%ac%d8%a7%d8%af_%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c_api_%d8%a8%d8%a7_nextjs\"><\/span>\u0627\u06cc\u062c\u0627\u062f \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc API \u0628\u0627 Next.js<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>Next.js \u0647\u0645\u0686\u0646\u06cc\u0646 \u06cc\u06a9 \u0648\u06cc\u0698\u06af\u06cc \u0628\u0631\u0627\u06cc \u062a\u0648\u0633\u0639\u0647 API \u062e\u0648\u062f \u0631\u0627 \u062f\u0631 \u062f\u0627\u062e\u0644 \u067e\u0631\u0648\u0698\u0647 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u062f process \u0634\u0628\u06cc\u0647 \u0627\u06cc\u062c\u0627\u062f \u0635\u0641\u062d\u0627\u062a \u0627\u0633\u062a!  \u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639\u060c \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f <code>api<\/code> \u0632\u06cc\u0631 \u0634\u0627\u062e\u0647 \u0632\u06cc\u0631 <code>\/pages<\/code> (\u06cc\u0639\u0646\u06cc <code>\/pages\/api<\/code>) \u0648 \u0647\u0631 \u0641\u0627\u06cc\u0644\u06cc \u062f\u0631 \u0627\u06cc\u0646 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0628\u0647 \u0622\u0646 \u0647\u062f\u0627\u06cc\u062a \u0645\u06cc \u0634\u0648\u062f <code>\/api\/*<\/code>.<\/p>\n<blockquote>\n<p>\u0628\u06af\u0648\u060c \u0645\u0627 \u06cc\u06a9 \u0641\u0627\u06cc\u0644 \u0627\u06cc\u062c\u0627\u062f \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>\/pages\/api\/weather.js<\/code>.  \u06cc\u06a9 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u0628\u0644\u0627\u0641\u0627\u0635\u0644\u0647 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0642\u0627\u0628\u0644 \u062f\u0633\u062a\u0631\u0633\u06cc \u0627\u0633\u062a <code>\/api\/weather<\/code>.<\/p>\n<\/blockquote>\n<p>\u0628\u0631\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0627\u06cc\u0646 \u0646\u0642\u0627\u0637 \u067e\u0627\u06cc\u0627\u0646\u06cc \u06a9\u0627\u0631 \u06a9\u0646\u0646\u062f\u060c \u0628\u0627\u06cc\u062f export \u06cc\u06a9 \u067e\u06cc\u0634 \u0641\u0631\u0636 <code>handler()<\/code> \u062a\u0627\u0628\u0639 (\u06a9\u0646\u062a\u0631\u0644 \u06a9\u0646\u0646\u062f\u0647 \u062f\u0631\u062e\u0648\u0627\u0633\u062a) \u0628\u0631\u0627\u06cc \u0647\u0631 \u0646\u0642\u0637\u0647 \u067e\u0627\u06cc\u0627\u0646\u06cc \u06a9\u0647 \u062f\u0648 \u067e\u0627\u0631\u0627\u0645\u062a\u0631 \u0631\u0627 \u062f\u0631\u06cc\u0627\u0641\u062a \u0645\u06cc \u06a9\u0646\u062f: <code>req<\/code> (\u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0648\u0631\u0648\u062f\u06cc)\u060c \u0648 <code>res<\/code> (\u067e\u0627\u0633\u062e \u0633\u0631\u0648\u0631).<\/p>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0645\u062a\u062d\u0627\u0646 \u06a9\u0631\u062f\u0646 \u0627\u06cc\u0646\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0645\u0627 \u0631\u0627 \u0628\u0647 \u0631\u0648\u0632 \u06a9\u0646\u06cc\u0645 <code>\/pages\/api\/weather.js<\/code> \u0645\u062b\u0627\u0644 \u0628\u0627 \u0645\u062d\u062a\u0648\u0627\u06cc \u0632\u06cc\u0631:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">handler<\/span>(<span class=\"hljs-params\">req, res<\/span>) <\/span>{\n  res.status(<span class=\"hljs-number\">200<\/span>)\n  res.json({\n    <span class=\"hljs-attr\">city<\/span>: <span class=\"hljs-string\">'London'<\/span>,\n    <span class=\"hljs-attr\">temperature<\/span>: <span class=\"hljs-string\">'20'<\/span>,\n    <span class=\"hljs-attr\">description<\/span>: <span class=\"hljs-string\">'sunny'<\/span>,\n  });\n}\n<\/code><\/pre>\n<p>\u062f\u0631 \u0635\u0648\u0631\u062a \u0628\u0627\u0632\u062f\u06cc\u062f \u06cc\u0627 \u0627\u0631\u0633\u0627\u0644 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0628\u0647 <code>\/api\/weather<\/code>\u060c \u0628\u0627\u06cc\u062f \u0628\u0628\u06cc\u0646\u06cc\u0645 \u06a9\u0647 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627\u06cc \u0633\u0627\u062e\u062a\u06af\u06cc \u0644\u0646\u062f\u0646 \u0628\u0627\u0632\u06af\u0631\u062f\u0627\u0646\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a\u060c \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 a <code>200<\/code> \u06a9\u062f \u067e\u0627\u0633\u062e.<\/p>\n<h3 id=\"staticassets\"><span class=\"ez-toc-section\" id=\"%d8%af%d8%a7%d8%b1%d8%a7%db%8c%db%8c_%d9%87%d8%a7%db%8c_%d8%a7%db%8c%d8%b3%d8%aa%d8%a7\"><\/span>\u062f\u0627\u0631\u0627\u06cc\u06cc \u0647\u0627\u06cc \u0627\u06cc\u0633\u062a\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0631 \u0628\u0631\u062e\u06cc \u0645\u0648\u0627\u0631\u062f\u060c \u0627\u062d\u062a\u0645\u0627\u0644\u0627\u064b \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u062f\u0627\u0631\u0627\u06cc\u06cc \u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f \u062a\u0635\u0627\u0648\u06cc\u0631\u060c \u0641\u06cc\u0644\u0645 \u0647\u0627\u060c \u0641\u0648\u0646\u062a \u0647\u0627 \u0648 \u063a\u06cc\u0631\u0647 \u0631\u0627 \u0628\u0627\u0631\u06af\u06cc\u0631\u06cc \u06a9\u0646\u06cc\u062f. \u0631\u0648\u06cc.  \u0647\u0645\u0647 \u067e\u0631\u0648\u0698\u0647 \u0647\u0627\u06cc Next.js \u062f\u0627\u0631\u0627\u06cc \u06cc\u06a9 \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0628\u0647 \u0646\u0627\u0645 \u0647\u0633\u062a\u0646\u062f <code>\/public<\/code> \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0646\u0638\u0648\u0631.<\/p>\n<blockquote>\n<p>\u0641\u0627\u06cc\u0644 \u0647\u0627 \u062f\u0631 <code>\/public<\/code> \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0627\u0632 \u0647\u0631 \u0646\u0642\u0637\u0647 \u062f\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0634\u0645\u0627 \u0628\u0627 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0646 \u0645\u0646\u0628\u0639 \u0627\u0635\u0644\u06cc \u0628\u0627 URL \u0627\u0635\u0644\u06cc (<code>\/<\/code>).<\/p>\n<\/blockquote>\n<p>\u0645\u062b\u0644\u0627\u064b \u0627\u06af\u0631 \u0641\u0627\u06cc\u0644\u06cc \u062f\u0631 \u0632\u06cc\u0631 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u0645 <code>\/public\/weather-icon.svg<\/code>\u060c \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u062f\u0631 \u0647\u0631 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> WeatherIcon = <span class=\"hljs-function\">() =&gt;<\/span> {\n  <span class=\"hljs-keyword\">return<\/span> <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">img<\/span> <span class=\"hljs-attr\">src<\/span>=<span class=\"hljs-string\">\"\/weather-icon.svg\"<\/span> <span class=\"hljs-attr\">alt<\/span>=<span class=\"hljs-string\">\"Weather Icon\"<\/span>\/&gt;<\/span><\/span>\n}\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> WeatherIcon\n<\/code><\/pre>\n<h3 id=\"nextjsenvironmentvariables\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%aa%d8%ba%db%8c%d8%b1%d9%87%d8%a7%db%8c_%d9%85%d8%ad%db%8c%d8%b7%db%8c_nextjs\"><\/span>\u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u06cc\u0637\u06cc Next.js<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u06cc\u0637\u06cc \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc\u06cc \u0647\u0633\u062a\u0646\u062f \u06a9\u0647 \u0645\u0642\u0627\u062f\u06cc\u0631 \u0622\u0646\u0647\u0627 \u062e\u0627\u0631\u062c \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u062a\u0646\u0638\u06cc\u0645 \u0634\u062f\u0647 \u0627\u0633\u062a \u0648 \u0645\u0627 \u0628\u06cc\u0634\u062a\u0631 \u0627\u0632 \u0622\u0646\u0647\u0627 \u0628\u0631\u0627\u06cc \u062d\u0641\u0638 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062d\u0633\u0627\u0633 \u0645\u0627\u0646\u0646\u062f \u06a9\u0644\u06cc\u062f\u0647\u0627\u06cc API \u06cc\u0627 \u062a\u0646\u0638\u06cc\u0645\u0627\u062a \u0633\u0631\u0648\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u062a\u0627 \u0627\u0632 \u0641\u0634\u0627\u0631 \u062f\u0627\u062f\u0646 \u0622\u0646\u0647\u0627 \u0628\u0647 \u0627\u0628\u0632\u0627\u0631\u0647\u0627\u06cc \u06a9\u0646\u062a\u0631\u0644 \u0646\u0633\u062e\u0647 \u0645\u0627\u0646\u0646\u062f GitHub\u060c GitLab \u0648 \u063a\u06cc\u0631\u0647 \u062c\u0644\u0648\u06af\u06cc\u0631\u06cc \u06a9\u0646\u06cc\u0645.<\/p>\n<p>Next.js \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc \u0627\u0632 \u06a9\u0627\u0631 \u0628\u0627 \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u06cc\u0637\u06cc \u0631\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 a <code>.env.local<\/code> \u0641\u0627\u06cc\u0644.  \u062a\u0645\u0627\u0645 \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u0627\u06cc\u0646 \u0641\u0627\u06cc\u0644 \u0628\u0647 \u0646\u06af\u0627\u0634\u062a \u0645\u06cc\u200c\u0634\u0648\u0646\u062f <code>process.env<\/code>.<\/p>\n<p>\u0627\u06af\u0631 \u0645\u0627 \u06cc\u06a9 <code>.env.local<\/code> \u0641\u0627\u06cc\u0644 \u0628\u0627 \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u0632\u06cc\u0631:<\/p>\n<pre><code class=\"hljs\">WEATHER_API_KEY=abcd123\nCITY_API_KEY=123abc\n<\/code><\/pre>\n<p>\u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0622\u0646\u0647\u0627 \u0628\u0647 \u0622\u0646\u0647\u0627 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u0645 <code>process.env.WEATHER_API_KEY<\/code> \u0648 <code>process.env.CITY_API_KEY<\/code>.<\/p>\n<p>\u0647\u0645\u0686\u0646\u06cc\u0646\u060c \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u06cc\u0637\u06cc \u0628\u0647 \u0637\u0648\u0631 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647 \u0646\u0645\u06cc \u0634\u0648\u0646\u062f \u0648 \u0641\u0642\u0637 \u062f\u0631 \u0645\u062d\u06cc\u0637 Node.js \u0642\u0627\u0628\u0644 \u062f\u0633\u062a\u0631\u0633\u06cc \u0647\u0633\u062a\u0646\u062f (\u0631\u0648\u06cc \u0633\u0645\u062a \u0633\u0631\u0648\u0631).  \u0628\u0627 \u0627\u06cc\u0646 \u062d\u0627\u0644\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0627 \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0646 \u067e\u06cc\u0634\u0648\u0646\u062f \u0645\u062a\u063a\u06cc\u0631 \u062a\u0631\u062c\u06cc\u062d\u06cc \u0628\u0627\u060c \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0631 \u0645\u0639\u0631\u0636 \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc \u0642\u0631\u0627\u0631 \u062f\u0647\u06cc\u0645 <code>NEXT_PUBLIC_<\/code>.  \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0627\u06af\u0631 \u06cc\u06a9 \u0645\u062a\u063a\u06cc\u0631 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\">NEXT_PUBLIC_CITY_API_KEY=123abc\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0645\u062a\u063a\u06cc\u0631 \u0627\u06a9\u0646\u0648\u0646 \u062f\u0631 \u0647\u0631 \u0646\u0642\u0637\u0647 \u0627\u0632 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u0642\u0627\u0628\u0644 \u062f\u0633\u062a\u0631\u0633\u06cc \u0627\u0633\u062a <code>process.env.NEXT_PUBLIC_CITY_API_KEY<\/code>.<\/p>\n<h2 id=\"buildingaweatherappwithnextjs\"><span class=\"ez-toc-section\" id=\"%d8%b3%d8%a7%d8%ae%d8%aa_%d8%a7%d9%be%d9%84%db%8c%da%a9%db%8c%d8%b4%d9%86_%d8%a2%d8%a8_%d9%88_%d9%87%d9%88%d8%a7_%d8%a8%d8%a7_nextjs\"><\/span>\u0633\u0627\u062e\u062a \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0628\u0627 Next.js<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<blockquote>\n<p>\u0645\u0627 \u0642\u0628\u0644\u0627\u064b \u0632\u0645\u06cc\u0646 \u0647\u0627\u06cc \u0632\u06cc\u0627\u062f\u06cc \u0631\u0627 \u067e\u0648\u0634\u0627\u0646\u062f\u0647 \u0627\u06cc\u0645!  \u062a\u062b\u0628\u06cc\u062a \u062f\u0627\u0646\u0634 \u062c\u062f\u06cc\u062f \u0628\u0647 \u0628\u0647\u062a\u0631\u06cc\u0646 \u0648\u062c\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u062a\u0645\u0631\u06cc\u0646 \u0628\u0647 \u062f\u0633\u062a \u0645\u06cc \u0622\u06cc\u062f\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc \u0628\u0631\u0627\u06cc \u062a\u06a9\u0645\u06cc\u0644 \u0646\u0638\u0631\u06cc\u0647 \u062c\u062f\u06cc\u062f \u0645\u0641\u06cc\u062f \u0627\u0633\u062a.<\/p>\n<\/blockquote>\n<p>\u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0622\u0628 \u0648 \u0647\u0648\u0627 \u062e\u0648\u0627\u0647\u06cc\u0645 \u0628\u0648\u062f \u06a9\u0647 \u0634\u0647\u0631 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0627 \u062a\u0634\u062e\u06cc\u0635 \u0645\u06cc \u062f\u0647\u062f \u0648 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0631\u0627 \u0628\u0631 \u0627\u0633\u0627\u0633 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u062f \u0631\u0648\u06cc \u0622\u0646 \u0627\u0637\u0644\u0627\u0639\u0627\u062a  \u0639\u0644\u0627\u0648\u0647 \u0628\u0631 \u0627\u06cc\u0646\u060c \u0645\u0627 \u0642\u0627\u0628\u0644\u06cc\u062a\u06cc \u0631\u0627 \u067e\u06cc\u0627\u062f\u0647 \u0633\u0627\u0632\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f \u06a9\u0647 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u0645\u06a9\u0627\u0646 \u0645\u06cc \u062f\u0647\u062f \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062e\u0627\u0635 \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0631\u0627 \u062f\u0631 \u0647\u0631 \u0644\u062d\u0638\u0647 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u0646\u062f \u0648 \u0628\u0639\u062f\u0627\u064b \u0628\u0647 \u0622\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f.<\/p>\n<p>\u0628\u0631\u0646\u0627\u0645\u0647 \u0686\u06cc\u0632\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 \u0627\u06cc\u0646 \u062e\u0648\u0627\u0647\u062f \u0628\u0648\u062f:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/guide-to-getting-started-with-nextjs-create-a-nextjs-app-5.png\" alt=\"\u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0628\u0627 next.js\" title=\"\"><\/p>\n<p>\u0627\u06af\u0631 \u0642\u0628\u0644\u0627\u064b \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0646\u06a9\u0631\u062f\u0647 \u0627\u06cc\u062f\u060c \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 Next.js \u062c\u062f\u06cc\u062f \u0628\u0627 \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npx create-next-app weather-app<\/span>\n<\/code><\/pre>\n<p>\u0648 \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u0628\u0627 \u0645\u0648\u0627\u0631\u062f \u0632\u06cc\u0631 \u0634\u0631\u0648\u0639 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm run dev<\/span>\n<\/code><\/pre>\n<p>\u0628\u0631\u0627\u06cc \u0633\u0627\u062f\u06af\u06cc \u0648 \u0627\u062e\u062a\u0635\u0627\u0631\u060c \u0645\u0627 \u0628\u0647 \u062c\u0627\u06cc \u0646\u0648\u0634\u062a\u0646 CSS \u0633\u0641\u0627\u0631\u0634\u06cc\u060c \u0627\u0632 Bootstrap \u0628\u0631\u0627\u06cc \u062a\u0646\u0638\u06cc\u0645 \u0631\u0627\u0628\u0637 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f.  \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062f\u0633\u062a\u0648\u0631 \u0632\u06cc\u0631 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u062f \u0628\u0648\u062a \u0627\u0633\u062a\u0631\u067e \u0631\u0627 \u0646\u0635\u0628 \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm install bootstrap<\/span>\n<\/code><\/pre>\n<p>\u067e\u0633 \u0627\u0632 \u0627\u062a\u0645\u0627\u0645 \u0646\u0635\u0628\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0627\u0632 \u06a9\u0646\u06cc\u0645 <code>pages\/_app.js<\/code> \u0648 \u0634\u0627\u0645\u0644 \u06cc\u06a9 \u0648\u0631\u0648\u062f\u06cc \u0628\u0631\u0627\u06cc Bootstrap:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> <span class=\"hljs-string\">\"bootstrap\/dist\/css\/bootstrap.css\"<\/span>;\n<span class=\"hljs-keyword\">import<\/span> <span class=\"hljs-string\">\"..\/styles\/globals.css\"<\/span>;\n\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">MyApp<\/span>(<span class=\"hljs-params\">{ Component, pageProps }<\/span>) <\/span>{\n  <span class=\"hljs-keyword\">return<\/span> <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Component<\/span> {<span class=\"hljs-attr\">...pageProps<\/span>} \/&gt;<\/span><\/span>;\n}\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> MyApp;\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> \u0627\u06cc\u0646 <code>_app.js<\/code> \u0641\u0627\u06cc\u0644 \u067e\u06cc\u0634 \u0641\u0631\u0636 \u0627\u0633\u062a <em>\u0628\u0631\u0646\u0627\u0645\u0647<\/em> \u062c\u0632\u0621 \u06a9\u0647 Next.js \u0628\u0631\u0627\u06cc \u0645\u0642\u062f\u0627\u0631\u062f\u0647\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0635\u0641\u062d\u0627\u062a \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u06a9\u0646\u062f.  \u0627\u06cc\u0646 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0646\u0642\u0637\u0647 \u0634\u0631\u0648\u0639 \u0628\u0631\u0627\u06cc \u0647\u0645\u0647 \u0634\u0645\u0627 \u0639\u0645\u0644 \u0645\u06cc \u06a9\u0646\u062f page\u0627\u062c\u0632\u0627\u06cc<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u0627\u06a9\u0646\u0648\u0646\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0627 \u062a\u063a\u06cc\u06cc\u0631 \u0641\u0648\u0646\u062a \u067e\u06cc\u0634\u200c\u0641\u0631\u0636 \u0648 \u0627\u0641\u0632\u0648\u062f\u0646 \u06cc\u06a9 \u0631\u0646\u06af \u067e\u0633\u200c\u0632\u0645\u06cc\u0646\u0647 \u0632\u06cc\u0628\u0627\u060c \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u062e\u0648\u062f \u0631\u0627 \u0627\u0632 \u0646\u0638\u0631 \u0628\u0635\u0631\u06cc \u062c\u0630\u0627\u0628\u200c\u062a\u0631 \u06a9\u0646\u06cc\u0645.  \u0628\u06cc\u0627 \u0628\u0627\u0632 \u06a9\u0646\u06cc\u0645 <code>styles\/global.css<\/code> \u0648 \u062a\u063a\u06cc\u06cc\u0631\u0627\u062a \u0632\u06cc\u0631 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">@import<\/span> url(<span class=\"hljs-string\">'https:\/\/fonts.googleapis.com\/css2\u061ffamily=Be+Vietnam+Pro:wght@100;200;300;400;500;800;900&amp;display=swap'<\/span>);\n\n<span class=\"hljs-selector-tag\">body<\/span> {\n  <span class=\"hljs-attribute\">background<\/span>: <span class=\"hljs-number\">#4F32FF<\/span>;\n  <span class=\"hljs-attribute\">color<\/span>: <span class=\"hljs-number\">#fff<\/span>;\n  <span class=\"hljs-attribute\">font-family<\/span>: <span class=\"hljs-string\">'Be Vietnam Pro'<\/span>, sans-serif;\n}\n<\/code><\/pre>\n<p>\u0627\u06cc\u0646 \u0628\u0631\u0627\u06cc \u0634\u0631\u0648\u0639 \u06a9\u0627\u0641\u06cc \u0627\u0633\u062a!  \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0633\u0627\u062e\u062a\u0627\u0631 \u0635\u0641\u062d\u0627\u062a \u0648 \u0645\u06a9\u0627\u0646\u200c\u0646\u0645\u0627\u0647\u0627\u06cc \u062e\u0648\u062f \u0631\u0627 \u0628\u0631\u0627\u06cc \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc\u06cc \u06a9\u0647 \u0627\u0632 \u0637\u0631\u06cc\u0642 \u06cc\u06a9 API \u0648\u0627\u06a9\u0634\u06cc \u0645\u06cc\u200c\u0634\u0648\u0646\u062f\u060c \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u0645.<\/p>\n<h3 id=\"pagemarkup\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%b4%d8%a7%d9%86%d9%87_%da%af%d8%b0%d8%a7%d8%b1%db%8c_%d8%b5%d9%81%d8%ad%d9%87\"><\/span>\u0646\u0634\u0627\u0646\u0647 \u06af\u0630\u0627\u0631\u06cc \u0635\u0641\u062d\u0647<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0628\u0631\u0627\u06cc \u0642\u0633\u0645\u062a \u062c\u0644\u0648\u06cc\u06cc \u0645\u0627\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0628\u0627\u0632 \u06a9\u0646\u06cc\u0645 <code>pages\/index.js<\/code> \u0648 \u0646\u0634\u0627\u0646\u0647 \u06af\u0630\u0627\u0631\u06cc (\u0633\u0627\u062e\u062a\u0627\u0631) \u062e\u0627\u0646\u0647 \u062e\u0648\u062f \u0631\u0627 \u062a\u0639\u0631\u06cc\u0641 \u06a9\u0646\u06cc\u062f page:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> Link <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"next\/link\"<\/span>;\n\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">Home<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n  <span class=\"hljs-keyword\">return<\/span> (\n    <span class=\"xml\"><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>\n        <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"d-flex justify-content-center align-items-center\"<\/span>\n        <span class=\"hljs-attr\">style<\/span>=<span class=\"hljs-string\">{{<\/span> <span class=\"hljs-attr\">minHeight:<\/span> \"<span class=\"hljs-attr\">100vh<\/span>\" }}\n      &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\">h1<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"fw-bolder\"<\/span> <span class=\"hljs-attr\">style<\/span>=<span class=\"hljs-string\">{{<\/span> <span class=\"hljs-attr\">fontSize:<\/span> \"<span class=\"hljs-attr\">60px<\/span>\" }}&gt;<\/span>\n              Null City.\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span>\n            13 January, 2022\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\">\"d-flex justify-content-between align-items-center mt-4\"<\/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\">\"pe-5\"<\/span>&gt;<\/span>\n              <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h2<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"d-inline\"<\/span>&gt;<\/span>0<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h2<\/span>&gt;<\/span>\n              <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">sup<\/span>&gt;<\/span>\u00b0C<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">sup<\/span>&gt;<\/span>\n              <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"text-info\"<\/span>&gt;<\/span>Cloudy<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>&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\">img<\/span> <span class=\"hljs-attr\">src<\/span>=<span class=\"hljs-string\">\"\/1.png\"<\/span> <span class=\"hljs-attr\">alt<\/span>=<span class=\"hljs-string\">\"\"<\/span> <span class=\"hljs-attr\">width<\/span>=<span class=\"hljs-string\">{100}<\/span> <span class=\"hljs-attr\">draggable<\/span>=<span class=\"hljs-string\">\"false\"<\/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\">hr<\/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\">\"d-md-flex justify-content-between align-items-center mt-4\"<\/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 btn-success border-0 save-btn px-4 py-3\"<\/span>&gt;<\/span>\n             Timestamp\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Link<\/span> <span class=\"hljs-attr\">href<\/span>=<span class=\"hljs-string\">\"\/history\"<\/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 btn-danger border-0 history-btn px-4 py-3 ms-auto\"<\/span>&gt;<\/span>\n                My History\n              <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">Link<\/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>\n    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span><\/span>\n  );\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 \u0628\u0627\u06cc\u062f \u0646\u0645\u0627\u062f \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0631\u0627 \u0627\u0632 \u0645\u0627 \u062f\u0627\u0646\u0644\u0648\u062f \u06a9\u0646\u06cc\u062f <a target=\"_blank\" href=\"https:\/\/github.com\/StackAbuse\/weather-app\/blob\/main\/public\/1.png\" rel=\"noopener\">GitHub<\/a>\u0648 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0628\u06af\u0646\u062c\u0627\u0646\u06cc\u062f <code>\/public<\/code> \u067e\u0648\u0634\u0647<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u0648 \u062f\u0631 \u0627\u06cc\u0646 \u0645\u0631\u062d\u0644\u0647\u060c \u0627\u06af\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u062e\u0648\u062f \u0631\u0627 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u067e\u06cc\u0634\u200c\u0646\u0645\u0627\u06cc\u0634 \u06a9\u0646\u06cc\u0645\u060c \u0628\u0627\u06cc\u062f \u062e\u0631\u0648\u062c\u06cc \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0627 \u062f\u0627\u062f\u0647\u200c\u0647\u0627\u06cc \u0633\u0627\u062e\u062a\u06af\u06cc \u0628\u0628\u06cc\u0646\u06cc\u0645:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/guide-to-getting-started-with-nextjs-create-a-nextjs-app-4.png\" alt=\"\u067e\u06cc\u0634 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0633\u0627\u062e\u062a\u06af\u06cc\" title=\"\"><\/p>\n<h3 id=\"gettingweatherinformation\"><span class=\"ez-toc-section\" id=\"%d8%af%d8%b1%db%8c%d8%a7%d9%81%d8%aa_%d8%a7%d8%b7%d9%84%d8%a7%d8%b9%d8%a7%d8%aa_%d8%a2%d8%a8_%d9%88_%d9%87%d9%88%d8%a7\"><\/span>\u062f\u0631\u06cc\u0627\u0641\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0645\u0627 \u0627\u0632 \u06cc\u06a9 API \u0631\u0627\u06cc\u06af\u0627\u0646 \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0628\u0631\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627\u06cc \u0641\u0639\u0644\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f\u060c \u0627\u0645\u0627 \u0686\u0648\u0646 \u0645\u06cc\u200c\u062e\u0648\u0627\u0647\u06cc\u0645 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627\u06cc \u0634\u0647\u0631\u06cc \u0631\u0627 \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631 \u062f\u0631 \u0622\u0646 \u0627\u0633\u062a \u0646\u0645\u0627\u06cc\u0634 \u062f\u0647\u06cc\u0645\u060c \u0628\u0627\u06cc\u062f \u0627\u0632 API \u062f\u06cc\u06af\u0631\u06cc \u0628\u0631\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u0634\u0647\u0631 \u0641\u0639\u0644\u06cc \u06a9\u0627\u0631\u0628\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 \u0648 \u0627\u06cc\u0646 \u0631\u0627 \u067e\u0627\u0633 \u06a9\u0646\u06cc\u0645. \u067e\u0627\u0631\u0627\u0645\u062a\u0631 \u0628\u0647 API \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0628\u0631\u0627\u06cc \u0628\u0647 \u062f\u0633\u062a \u0622\u0648\u0631\u062f\u0646 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0648\u0631\u062f \u0646\u0638\u0631.<\/p>\n<p>\u062a\u0635\u0648\u06cc\u0631 \u0632\u06cc\u0631 \u0627\u06cc\u0646 \u0645\u0648\u0636\u0648\u0639 \u0631\u0627 \u062a\u0648\u0636\u06cc\u062d \u0645\u06cc \u062f\u0647\u062f process<\/p>\n<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/guide-to-getting-started-with-nextjs-create-a-nextjs-app-3.png\" alt=\"\u062f\u0633\u062a\u0648\u0631 \u0639\u0645\u0644\u06cc\u0627\u062a \u0628\u0631\u0646\u0627\u0645\u0647\" title=\"\"><\/p>\n<p>\u0628\u0631\u0627\u06cc \u0628\u0647 \u062f\u0633\u062a \u0622\u0648\u0631\u062f\u0646 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627\u060c \u0645\u0627 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f <a target=\"_blank\" rel=\"nofollow noopener noreferrer\" href=\"https:\/\/openweathermap.org\/api\"><strong><em>OpenWeather API<\/em><\/strong><\/a>\u060c \u0648 \u062f\u0631 \u062d\u0627\u0644\u06cc \u06a9\u0647 \u0622\u0646\u0647\u0627 \u06cc\u06a9 \u0637\u0631\u062d \u0631\u0627\u06cc\u06af\u0627\u0646 \u0627\u0631\u0627\u0626\u0647 \u0645\u06cc \u062f\u0647\u0646\u062f\u060c \u0628\u0631\u0627\u06cc \u0628\u0647 \u062f\u0633\u062a \u0622\u0648\u0631\u062f\u0646 \u06cc\u06a9 \u06a9\u0644\u06cc\u062f API \u0628\u0627\u06cc\u062f \u06cc\u06a9 \u062d\u0633\u0627\u0628 \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f.<\/p>\n<p>\u0648 \u0628\u0631\u0627\u06cc \u0628\u0627\u0632\u06cc\u0627\u0628\u06cc \u0634\u0647\u0631 \u06a9\u0627\u0631\u0628\u0631\u060c \u0627\u0632 \u06cc\u06a9 \u0631\u0627\u06cc\u06af\u0627\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f <a target=\"_blank\" rel=\"nofollow noopener noreferrer\" href=\"https:\/\/ip-api.com\/\"><strong><em>IP Geolocation API<\/em><\/strong><\/a>  \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u06a9\u0644\u06cc\u062f API \u0646\u062f\u0627\u0631\u062f.<\/p>\n<p>\u0647\u0645\u0686\u0646\u06cc\u0646\u060c \u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u0645 \u06a9\u0647 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0628\u0644\u0627\u0641\u0627\u0635\u0644\u0647 \u067e\u0633 \u0627\u0632 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f page \u0628\u0627\u0631\u06af\u0630\u0627\u0631\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 Next.js <code>getServerSideProps()<\/code> \u062f\u0631 \u0627\u06cc\u0646\u062c\u0627 \u0628\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u0622\u06cc\u062f!<\/p>\n<p>\u062d\u0627\u0644\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u0635\u0627\u062f\u0631\u0627\u062a \u0632\u06cc\u0631 \u0631\u0627 \u0628\u0647 \u0622\u0646 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645 <code>index.js<\/code> \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u062a\u0645\u0627\u0645 \u0639\u0645\u0644\u06a9\u0631\u062f\u0647\u0627\u06cc \u0630\u06a9\u0631 \u0634\u062f\u0647 \u062f\u0631 \u0628\u0627\u0644\u0627:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">async<\/span> <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">getServerSideProps<\/span>(<span class=\"hljs-params\"><\/span>) <\/span>{\n  <span class=\"hljs-keyword\">const<\/span> ipRequest = <span class=\"hljs-keyword\">await<\/span> fetch(<span class=\"hljs-string\">`http:\/\/ip-api.com\/json\/`<\/span>);\n  <span class=\"hljs-keyword\">const<\/span> ipData = <span class=\"hljs-keyword\">await<\/span> ipRequest.json();\n  <span class=\"hljs-keyword\">const<\/span> city = ipData.regionName;\n\n  <span class=\"hljs-keyword\">const<\/span> api_key = <span class=\"hljs-string\">'YOUR_OPEN-WEATHER_API_KEY'<\/span>;\n  <span class=\"hljs-keyword\">const<\/span> url = <span class=\"hljs-string\">`http:\/\/api.openweathermap.org\/data\/2.5\/weather\u061fq=<span class=\"hljs-subst\">${city}<\/span>,&amp;appid=<span class=\"hljs-subst\">${api_key}<\/span>&amp;units=metric`<\/span>;\n  <span class=\"hljs-keyword\">const<\/span> weatherRequest = <span class=\"hljs-keyword\">await<\/span> fetch(url);\n  <span class=\"hljs-keyword\">const<\/span> weatherInfo = <span class=\"hljs-keyword\">await<\/span> weatherRequest.json();\n\n  <span class=\"hljs-built_in\">console<\/span>.log(weatherInfo);\n  <span class=\"hljs-keyword\">return<\/span> { <span class=\"hljs-attr\">props<\/span>: { weatherInfo, city } };\n}\n<\/code><\/pre>\n<p>\u06a9\u062f \u0628\u0627\u0644\u0627 \u062f\u0648 \u0639\u0645\u0644\u06cc\u0627\u062a \u0646\u0627\u0647\u0645\u0632\u0645\u0627\u0646 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u062f\u0647\u062f:<\/p>\n<ul>\n<li>\u0627\u0648\u0644\u06cc\u0646 \u0645\u0648\u0631\u062f \u0628\u0627\u0632\u06cc\u0627\u0628\u06cc \u0634\u0647\u0631 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0633\u062a \u06a9\u0647 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0645\u062a\u063a\u06cc\u0631\u06cc \u0628\u0647 \u0646\u0627\u0645 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>city<\/code>.<\/li>\n<li>\u062f\u0648\u0645 \u0627\u0631\u0633\u0627\u0644 \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0628\u0647 API \u0622\u0628 \u0648 \u0647\u0648\u0627.<\/li>\n<\/ul>\n<p>\u0648 \u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u0645\u0627 \u0646\u062a\u06cc\u062c\u0647 \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f\u0647 \u0634\u062f\u0647 \u0627\u0632 API \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0634\u0647\u0631 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u067e\u0634\u062a\u0648\u0627\u0646\u0647 \u0627\u06cc \u0628\u0631\u0627\u06cc \u0646\u0645\u0627\u06cc\u0647 \u062e\u0648\u062f \u067e\u0627\u0633 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u0645. page.<\/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> \u0634\u0645\u0627 \u0628\u0627\u06cc\u062f \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u06a9\u0646\u06cc\u062f <code>YOUR_OPEN-WEATHER_API_KEY<\/code> \u0628\u0627 \u06a9\u0644\u06cc\u062f OpenWeather API \u062e\u0648\u062f\u062a\u0627\u0646.<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0645\u0648\u0631\u062f \u0646\u06cc\u0627\u0632 \u0627\u06a9\u0646\u0648\u0646 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u067e\u0627\u06cc\u0647 \u0628\u0631\u0627\u06cc \u0646\u0645\u0627\u06cc\u0647 \u0645\u0627 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u0634\u0648\u062f page \u06a9\u0647 \u062f\u0631 <code>weatherInfo<\/code> \u0648 <code>city<\/code>\u060c \u0648 \u0645\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u0637\u0631\u06cc\u0642:<\/p>\n<pre><code class=\"hljs\">...\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> <span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">Home<\/span>(<span class=\"hljs-params\">{ weatherInfo, city }<\/span>) <\/span>{\n...\n}\n<\/code><\/pre>\n<p>\u0627\u06af\u0631 \u0633\u0639\u06cc \u0645\u06cc \u06a9\u0646\u06cc\u062f \u0648\u0627\u0631\u062f \u0634\u0648\u06cc\u062f <code>weatherInfo<\/code> \u0628\u0647 console\u060c \u0645\u062a\u0648\u062c\u0647 \u062e\u0648\u0627\u0647\u06cc\u062f \u0634\u062f \u06a9\u0647 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0632\u06cc\u0627\u062f\u06cc \u0627\u0632 \u062c\u0645\u0644\u0647 \u0645\u062e\u062a\u0635\u0627\u062a \u06a9\u0627\u0631\u0628\u0631 \u0648 \u0628\u0631\u062e\u06cc \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062f\u06cc\u06af\u0631 \u06a9\u0647 \u0628\u0631\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0644\u0627\u0632\u0645 \u0646\u06cc\u0633\u062a\u060c \u0628\u0627\u0632\u06af\u0631\u062f\u0627\u0646\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0628\u0627 \u062a\u0648\u062c\u0647 \u0628\u0647 \u0637\u0631\u0627\u062d\u06cc \u0627\u067e\u0644\u06cc\u06a9\u06cc\u0634\u0646 \u0645\u0627\u060c \u0641\u0642\u0637 \u0628\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0632\u06cc\u0631 \u0646\u06cc\u0627\u0632 \u062f\u0627\u0631\u06cc\u0645:<\/p>\n<ul>\n<li>\u0634\u0647\u0631 \u06a9\u0627\u0631\u0628\u0631<\/li>\n<li>\u062f\u0645\u0627\u06cc \u0641\u0639\u0644\u06cc<\/li>\n<li>\u0634\u0631\u062d \u0622\u0628 \u0648 \u0647\u0648\u0627 (\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644 \u0627\u0628\u0631\u06cc\u060c \u0628\u0627\u0631\u0627\u0646 \u062e\u0641\u06cc\u0641\u060c \u0628\u0631\u0641\u060c \u0648 \u063a\u06cc\u0631\u0647)<\/li>\n<\/ul>\n<p>\u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u06cc\u06a9 \u0646\u0645\u0627\u062f \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0628\u0631 \u0627\u0633\u0627\u0633 \u0631\u0648\u06cc \u062f\u0645\u0627\u06cc \u0641\u0639\u0644\u06cc  \u062f\u0645\u0627\u06cc \u0641\u0639\u0644\u06cc \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f <code>weatherInfo.main.temp<\/code>\u060c \u0648 \u062a\u0648\u0636\u06cc\u062d\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627 \u062f\u0631 <code>weatherInfo.weather(0).description<\/code>.<\/p>\n<p>\u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u0627\u062c\u0627\u0632\u0647 \u062f\u0647\u06cc\u062f \u067e\u06cc\u0634 \u0628\u0631\u0648\u06cc\u0645 \u0648 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0633\u0627\u062e\u062a\u06af\u06cc \u0631\u0627 \u062f\u0631 \u0646\u0634\u0627\u0646\u0647 \u06af\u0630\u0627\u0631\u06cc \u062e\u0648\u062f \u0628\u0627 \u0627\u06cc\u0646 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u06a9\u0646\u06cc\u0645:<\/p>\n<pre><code class=\"hljs\">{<span class=\"hljs-comment\">\/* ... *\/<\/span>}\n&lt;div&gt;\n  <span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h1<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"fw-bolder\"<\/span> <span class=\"hljs-attr\">style<\/span>=<span class=\"hljs-string\">{{fontsize:<\/span> \"<span class=\"hljs-attr\">60px<\/span>\"}}&gt;<\/span>\n    {city}\n  <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h1<\/span>&gt;<\/span><\/span>\n  <span class=\"hljs-number\">13<\/span> January, <span class=\"hljs-number\">2022<\/span>\n&lt;\/div&gt;\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\">\"d-flex justify-content-between align-items-center mt-4\"<\/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\">\"pe-5\"<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h2<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"d-inline\"<\/span>&gt;<\/span>\n        {Math.round(weatherInfo.main.temp)}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h2<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">sup<\/span>&gt;<\/span>\u00b0C<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">sup<\/span>&gt;<\/span>\n    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"text-info text-capitalize\"<\/span>&gt;<\/span>\n        {weatherInfo.weather(0).description}\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>&gt;<\/span>\n  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>&gt;<\/span><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">img<\/span> <span class=\"hljs-attr\">src<\/span>=<span class=\"hljs-string\">'\/1.png'<\/span> <span class=\"hljs-attr\">alt<\/span>=<span class=\"hljs-string\">\"\"<\/span> <span class=\"hljs-attr\">width<\/span>=<span class=\"hljs-string\">{100}<\/span> <span class=\"hljs-attr\">draggable<\/span>=<span class=\"hljs-string\">\"false\"<\/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><\/span>\n{<span class=\"hljs-comment\">\/* ... *\/<\/span>}\n<\/code><\/pre>\n<p>\u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 OpenWeather API \u0628\u0631\u0627\u06cc \u062f\u0631\u06cc\u0627\u0641\u062a \u0646\u0645\u0627\u062f \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 \u0631\u0648\u06cc \u062f\u0645\u0627\u06cc \u0641\u0639\u0644\u06cc \u0631\u0627 \u0628\u0647 \u0633\u0627\u062f\u06af\u06cc \u0628\u0627 \u0639\u0628\u0648\u0631 \u0646\u0627\u0645 \u0646\u0645\u0627\u062f \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u067e\u0627\u0631\u0627\u0645\u062a\u0631\u060c \u0648 \u062e\u0648\u0634\u0628\u062e\u062a\u0627\u0646\u0647 \u0627\u06cc\u0646 \u0646\u06cc\u0632 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0627\u0633\u062a <code>$weatherInfo.weather(0).icon<\/code>.<\/p>\n<p>\u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646\u060c \u0628\u06cc\u0627\u06cc\u06cc\u062f \u062c\u0644\u0648 \u0628\u0631\u0648\u06cc\u0645 \u0648 \u0646\u0645\u0627\u062f \u0631\u0627 \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u06a9\u0646\u06cc\u0645 <code>&lt;img&gt;<\/code> \u0628\u0627 \u06a9\u062f \u0632\u06cc\u0631 \u062a\u06af \u06a9\u0646\u06cc\u062f:<\/p>\n<pre><code class=\"hljs\">{<span class=\"hljs-comment\">\/* ... *\/<\/span>}\n&lt;img\n  src={<span class=\"hljs-string\">`http:\/\/openweathermap.org\/img\/wn\/<span class=\"hljs-subst\">${weatherInfo.weather(<span class=\"hljs-number\">0<\/span>).icon}<\/span>@2x.png`<\/span>}\n\/&gt;\n{<span class=\"hljs-comment\">\/* ... *\/<\/span>}\n<\/code><\/pre>\n<p>\u0648 \u0628\u0631\u0646\u0627\u0645\u0647 \u0645\u0627 \u0628\u0627\u06cc\u062f \u06a9\u0627\u0645\u0644\u0627\u064b \u0639\u0645\u0644\u06cc\u0627\u062a\u06cc \u0628\u0627\u0634\u062f \u0648 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627\u06cc \u0641\u0639\u0644\u06cc \u0631\u0627 \u0646\u0645\u0627\u06cc\u0634 \u062f\u0647\u062f \u0631\u0648\u06cc \u0634\u0647\u0631\u06cc \u06a9\u0647 \u062f\u0631 \u062d\u0627\u0644 \u062d\u0627\u0636\u0631 \u062f\u0631 \u0622\u0646 \u0647\u0633\u062a\u06cc\u0645:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/guide-to-getting-started-with-nextjs-create-a-nextjs-app-5.png\" alt=\"\u067e\u06cc\u0634 \u0646\u0645\u0627\u06cc\u0634 \u06a9\u0627\u0631\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 next.js\" title=\"\"><\/p>\n<h3 id=\"savingdatalocally\"><span class=\"ez-toc-section\" id=\"%d8%b0%d8%ae%db%8c%d8%b1%d9%87_%d8%af%d8%a7%d8%af%d9%87_%d9%87%d8%a7_%d8%a8%d9%87_%d8%b5%d9%88%d8%b1%d8%aa_%d9%85%d8%ad%d9%84%db%8c\"><\/span>\u0630\u062e\u06cc\u0631\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0628\u0647 \u0635\u0648\u0631\u062a \u0645\u062d\u0644\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062d\u0627\u0644\u0627 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u062a\u0627\u0628\u0639\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627\u06cc \u0641\u0639\u0644\u06cc \u0648 \u0647\u0645\u0686\u0646\u06cc\u0646 \u062a\u0627\u0631\u06cc\u062e \u0648 \u0632\u0645\u0627\u0646 \u0630\u062e\u06cc\u0631\u0647 \u0622\u0646 \u0631\u0627 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u062f. <code>localStorage<\/code>.  \u0647\u0631 \u0648\u0631\u0648\u062f\u06cc \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0634\u06cc \u0628\u0627 \u0633\u0627\u062e\u062a\u0627\u0631 \u0632\u06cc\u0631 \u0630\u062e\u06cc\u0631\u0647 \u0645\u06cc \u0634\u0648\u062f:<\/p>\n<pre><code class=\"hljs\">{\n  date: 'Current Date',\n  time: 'Current Time',\n  city: 'User\\'s City',\n  temperature: 'User\\'s city temperature',\n  description: 'Weather Description',\n};\n<\/code><\/pre>\n<p>\u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631\u060c \u06cc\u06a9 \u062a\u0627\u0628\u0639 \u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f <code>saveWeather()<\/code> (\u0647\u0646\u0648\u0632 \u062f\u0627\u062e\u0644 \u0645\u0627\u0633\u062a <code>index.js<\/code> \u0641\u0627\u06cc\u0644) \u0628\u0627 \u06a9\u062f \u0632\u06cc\u0631:<\/p>\n<pre><code class=\"hljs\">  <span class=\"hljs-keyword\">const<\/span> saveWeather = <span class=\"hljs-function\">() =&gt;<\/span> {\n    <span class=\"hljs-keyword\">const<\/span> date = <span class=\"hljs-keyword\">new<\/span> <span class=\"hljs-built_in\">Date<\/span>();\n\n    <span class=\"hljs-keyword\">let<\/span> data = {\n      <span class=\"hljs-attr\">date<\/span>: <span class=\"hljs-string\">`<span class=\"hljs-subst\">${date.getDate()}<\/span> <span class=\"hljs-subst\">${date.getMonth() + <span class=\"hljs-number\">1<\/span>}<\/span> <span class=\"hljs-subst\">${date.getFullYear()}<\/span>`<\/span>,\n      <span class=\"hljs-attr\">time<\/span>: date.toLocaleTimeString(),\n      <span class=\"hljs-attr\">city<\/span>: city,\n      <span class=\"hljs-attr\">temperature<\/span>: weatherInfo.main.temp,\n      <span class=\"hljs-attr\">description<\/span>: weatherInfo.weather(<span class=\"hljs-number\">0<\/span>).description,\n    };\n\n    <span class=\"hljs-keyword\">let<\/span> previousData = <span class=\"hljs-built_in\">localStorage<\/span>.getItem(<span class=\"hljs-string\">'weatherHistory'<\/span>);\n    previousData = <span class=\"hljs-built_in\">JSON<\/span>.parse(previousData);\n    <span class=\"hljs-keyword\">if<\/span> (previousData === <span class=\"hljs-literal\">null<\/span>) {\n      previousData = ();\n    }\n    previousData.push(data);\n    <span class=\"hljs-built_in\">localStorage<\/span>.setItem(<span class=\"hljs-string\">'weatherHistory'<\/span>, <span class=\"hljs-built_in\">JSON<\/span>.stringify(previousData));\n    alert(<span class=\"hljs-string\">'Weather saved successfully'<\/span>);\n  };\n<\/code><\/pre>\n<p>\u06a9\u062f \u0628\u0627\u0644\u0627 \u0647\u0631 \u062f\u0627\u062f\u0647 \u0627\u06cc \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u062f\u0631 \u0622\u0646 \u0630\u062e\u06cc\u0631\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0631\u0627 \u062a\u062c\u0632\u06cc\u0647 \u0645\u06cc \u06a9\u0646\u062f <code>localStorage.weatherHistory<\/code> \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 JSON \u0648 \u0628\u0633\u062a\u0647 \u0628\u0647 \u0631\u0648\u06cc \u0646\u0648\u0639 \u062f\u0627\u062f\u0647 \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f\u0647 \u0634\u062f\u0647\u060c \u0648\u0631\u0648\u062f\u06cc \u062c\u062f\u06cc\u062f \u062e\u0648\u062f \u0631\u0627 \u0628\u0647 \u06cc\u06a9 \u0622\u0631\u0627\u06cc\u0647 \u0641\u0634\u0627\u0631 \u062f\u0627\u062f\u0647 \u0627\u06cc\u0645\u060c \u0627\u06cc\u0646 \u0622\u0631\u0627\u06cc\u0647 \u0631\u0627 \u0628\u0647 \u0631\u0634\u062a\u0647 \u062a\u0628\u062f\u06cc\u0644 \u06a9\u0631\u062f\u0647 \u0648 \u0622\u0646 \u0631\u0627 \u062f\u0631 <code>localStorage.weatherHistory<\/code>.  \u0645\u0627 \u0628\u0627\u06cc\u062f \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0631\u0627 \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645 \u0632\u06cc\u0631\u0627 <code>localStorage<\/code> \u0641\u0642\u0637 \u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0631\u0634\u062a\u0647 \u0647\u0627 \u0631\u0627 \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u062f \u0648 \u0627\u0646\u0648\u0627\u0639 \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u062f\u06cc\u06af\u0631 \u0631\u0627 \u0646\u0645\u06cc \u062a\u0648\u0627\u0646\u062f \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u062f.<\/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\u062e\u0648\u0627\u0646\u06cc\u062f <code>localStorage<\/code> &#8211; \u0631\u0627\u0647\u0646\u0645\u0627\u06cc \u0645\u0627 \u0628\u0631\u0627\u06cc \u0630\u062e\u06cc\u0631\u0647 \u062f\u0627\u062f\u0647 \u0647\u0627 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0628\u0627 LocalStorage \u0631\u0627 \u0628\u062e\u0648\u0627\u0646\u06cc\u062f!<\/p>\n<\/blockquote>\n<p>\u0648 \u0627\u0644\u0628\u062a\u0647\u060c \u0645\u0627 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u0627\u06cc\u0646 \u062a\u0627\u0628\u0639 \u0631\u0627 \u0632\u0645\u0627\u0646\u06cc \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0631\u0648\u06cc \u0622\u0646 \u06a9\u0644\u06cc\u06a9 \u0645\u06cc \u06a9\u0646\u062f <em>\u0645\u0647\u0631 \u0632\u0645\u0627\u0646<\/em> \u062f\u06a9\u0645\u0647\u060c \u067e\u0633 \u0628\u06cc\u0627\u06cc\u06cc\u062f \u06cc\u06a9 \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645 <code>onClick<\/code> \u0648\u06cc\u0698\u06af\u06cc \u0628\u0647 \u062f\u06a9\u0645\u0647:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">button<\/span> <span class=\"hljs-attr\">onClick<\/span>=<span class=\"hljs-string\">{saveWeather}<\/span>&gt;<\/span>Timestamp<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">button<\/span>&gt;<\/span>\n<\/code><\/pre>\n<h3 id=\"weatherhistorypage\"><span class=\"ez-toc-section\" id=\"%d8%b5%d9%81%d8%ad%d9%87_%d8%aa%d8%a7%d8%b1%db%8c%d8%ae%da%86%d9%87_%d8%a2%d8%a8_%d9%88_%d9%87%d9%88%d8%a7\"><\/span>\u0635\u0641\u062d\u0647 \u062a\u0627\u0631\u06cc\u062e\u0686\u0647 \u0622\u0628 \u0648 \u0647\u0648\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0631 \u0646\u0647\u0627\u06cc\u062a\u060c \u0645\u0627 \u0646\u06cc\u0627\u0632 \u0628\u0647 \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 \u0627\u062e\u062a\u0635\u0627\u0635\u06cc \u062f\u0627\u0631\u06cc\u0645 page \u0628\u0631\u0627\u06cc \u062f\u0633\u062a\u0631\u0633\u06cc \u0628\u0647 \u062a\u0645\u0627\u0645 \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627 \u06a9\u0647 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u0645\u0627 \u0630\u062e\u06cc\u0631\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a <code>localStorage<\/code>.<\/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\u0627 \u0646\u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u062a\u0648\u0627\u0628\u0639 \u0648\u0627\u06a9\u0634\u06cc \u062f\u0627\u062f\u0647 Next.js \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 \u0632\u06cc\u0631\u0627 <code>localStorage<\/code> \u06cc\u0627 \u0647\u0631 \u0634\u06cc \u0633\u0646\u062f \u062f\u06cc\u06af\u0631\u06cc \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0646\u06cc\u0633\u062a \u0631\u0648\u06cc \u0633\u0631\u0648\u0631\u060c \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0645\u0627 \u0628\u0627\u06cc\u062f \u062a\u06a9\u06cc\u0647 \u06a9\u0646\u06cc\u0645 \u0631\u0648\u06cc \u0648\u0627\u06a9\u0634\u06cc \u062f\u0627\u062f\u0647 \u0647\u0627\u06cc \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc<\/p>\n<\/p><\/div><\/div><\/div>\n<p>\u062c\u062f\u06cc\u062f \u0627\u06cc\u062c\u0627\u062f \u06a9\u0646\u06cc\u062f <code>history.js<\/code> \u0641\u0627\u06cc\u0644 \u0632\u06cc\u0631 <code>pages<\/code> \u062f\u0627\u06cc\u0631\u06a9\u062a\u0648\u0631\u06cc \u0628\u0627 \u0645\u062d\u062a\u0648\u0627\u06cc \u0632\u06cc\u0631:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { useState, useEffect } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">\"react\"<\/span>;\n\n<span class=\"hljs-keyword\">const<\/span> History = <span class=\"hljs-function\">(<span class=\"hljs-params\">{}<\/span>) =&gt;<\/span> {\n  <span class=\"hljs-keyword\">const<\/span> (weatherHistory, setweatherHistory) = useState(());\n\n\n  useEffect(<span class=\"hljs-function\">() =&gt;<\/span> {\n    setweatherHistory(\n      <span class=\"hljs-built_in\">localStorage<\/span>.weatherHistory !== <span class=\"hljs-literal\">undefined<\/span>\n        ? <span class=\"hljs-built_in\">JSON<\/span>.parse(<span class=\"hljs-built_in\">localStorage<\/span>.weatherHistory)\n        : ()\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>\n      <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"d-flex justify-content-center align-items-center p-3\"<\/span>\n      <span class=\"hljs-attr\">style<\/span>=<span class=\"hljs-string\">{{<\/span> <span class=\"hljs-attr\">minHeight:<\/span> \"<span class=\"hljs-attr\">100vh<\/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\">h2<\/span>&gt;<\/span>My Weather History<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h2<\/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\">\"mt-5\"<\/span>&gt;<\/span>\n          {weatherHistory.length &gt; 0 ? (\n            weatherHistory.map((weather, index) =&gt; {\n              return (\n                <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span>\n                  <span class=\"hljs-attr\">key<\/span>=<span class=\"hljs-string\">{index}<\/span>\n                  <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"card mb-3\"<\/span>\n                  <span class=\"hljs-attr\">style<\/span>=<span class=\"hljs-string\">{{<\/span> <span class=\"hljs-attr\">width:<\/span> \"<span class=\"hljs-attr\">450px<\/span>\" }}\n                &gt;<\/span>\n                  <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">div<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"card-body text-dark\"<\/span>&gt;<\/span>\n                    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">h5<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"card-title \"<\/span>&gt;<\/span>\n                      {weather.city} - {weather.date}\n                    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">h5<\/span>&gt;<\/span>\n                    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">small<\/span>&gt;<\/span>{weather.time}<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">small<\/span>&gt;<\/span>\n                    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">hr<\/span> \/&gt;<\/span>\n                    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"card-text\"<\/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\">\"font-weight-bold\"<\/span>&gt;<\/span>Temperature: <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&gt;<\/span>\n                      {weather.temperature}\n                      <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">sup<\/span>&gt;<\/span>\u00b0C<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">sup<\/span>&gt;<\/span>\n                    <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">p<\/span>&gt;<\/span>\n                    <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span> <span class=\"hljs-attr\">className<\/span>=<span class=\"hljs-string\">\"card-text\"<\/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\">\"font-weight-bold\"<\/span>&gt;<\/span>Condition: <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">span<\/span>&gt;<\/span>\n                      {weather.description}\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>&gt;<\/span>\n                <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">div<\/span>&gt;<\/span>\n              );\n            })\n          ) : (\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">p<\/span>&gt;<\/span>Nothing to see here - yet<span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">p<\/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\">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> History;\n<\/code><\/pre>\n<p>\u06a9\u062f \u0628\u0627\u0644\u0627 \u0628\u0631\u0631\u0633\u06cc \u0645\u06cc \u06a9\u0646\u062f \u06a9\u0647 \u0622\u06cc\u0627 <code>localStorage.weatherHistory<\/code> \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f\u060c \u062f\u0631 \u0635\u0648\u0631\u062a \u0648\u062c\u0648\u062f &#8211; \u0645\u0627 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u062a\u062c\u0632\u06cc\u0647 \u0645\u06cc \u06a9\u0646\u06cc\u0645 \u0648 \u0622\u0646 \u0631\u0627 \u0631\u0648\u06cc \u06cc\u06a9 \u0645\u062a\u063a\u06cc\u0631 \u062c\u062f\u06cc\u062f \u062a\u0646\u0638\u06cc\u0645 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>weatherHistory<\/code>.  \u0627\u06af\u0631 \u0627\u06cc\u0646\u0637\u0648\u0631 \u0646\u06cc\u0633\u062a\u060c \u0628\u0647 \u062c\u0627\u06cc \u0622\u0646\u060c \u0627\u06cc\u0646 \u0645\u062a\u063a\u06cc\u0631 \u0631\u0627 \u0631\u0648\u06cc \u06cc\u06a9 \u0622\u0631\u0627\u06cc\u0647 \u062e\u0627\u0644\u06cc \u0642\u0631\u0627\u0631 \u062f\u0627\u062f\u0647 \u0627\u06cc\u0645.<\/p>\n<p>\u062f\u0631 \u0646\u0634\u0627\u0646\u0647\u200c\u06af\u0630\u0627\u0631\u06cc\u060c \u0628\u0631\u0631\u0633\u06cc \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645 \u06a9\u0647 \u0622\u06cc\u0627 \u062d\u062f\u0627\u0642\u0644 \u06cc\u06a9 \u0648\u0631\u0648\u062f\u06cc \u062f\u0627\u062f\u0647 \u062f\u0631 \u0645\u0627 \u0648\u062c\u0648\u062f \u062f\u0627\u0631\u062f \u06cc\u0627 \u062e\u06cc\u0631 <code>weatherHistory<\/code> \u0622\u0631\u0627\u06cc\u0647 \u0648 \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a <code>.map()<\/code> \u062a\u0627\u0628\u0639\u060c \u0645\u0627 \u062f\u0631 \u062a\u0645\u0627\u0645 \u0645\u0648\u0627\u0631\u062f \u0645\u0648\u062c\u0648\u062f \u062f\u0631 \u0622\u0646 \u062a\u06a9\u0631\u0627\u0631 \u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>weatherHistory<\/code>\u060c \u0622\u0646\u0647\u0627 \u0631\u0627 \u062f\u0631 \u0635\u0641\u062d\u0647 \u0648\u0628 \u0645\u0627 \u0646\u0645\u0627\u06cc\u0634 \u0645\u06cc \u062f\u0647\u06cc\u0645.<\/p>\n<p>\u0628\u06cc\u0627\u06cc\u06cc\u062f \u062c\u0644\u0648 \u0628\u0631\u0648\u06cc\u0645 \u0648 \u0631\u0648\u06cc \u0622\u0646 \u06a9\u0644\u06cc\u06a9 \u06a9\u0646\u06cc\u0645 <em>\u0645\u0647\u0631 \u0632\u0645\u0627\u0646<\/em> \u062f\u06a9\u0645\u0647 \u0631\u0648\u06cc \u0634\u0627\u062e\u0635 page \u0628\u0631\u0627\u06cc \u062b\u0628\u062a \u0627\u0637\u0644\u0627\u0639\u0627\u062a \u0622\u0628 \u0648 \u0647\u0648\u0627\u06cc \u0641\u0639\u0644\u06cc \u0648 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0628\u0647 \u062a\u0627\u0631\u06cc\u062e\u0686\u0647 \u0628\u0627\u0632 \u0645\u06cc \u06af\u0631\u062f\u06cc\u062f page\u060c \u0628\u0627\u06cc\u062f \u0686\u06cc\u0632\u06cc \u0634\u0628\u06cc\u0647 \u0628\u0647 \u0627\u06cc\u0646 \u0631\u0627 \u0628\u0628\u06cc\u0646\u06cc\u062f:<\/p>\n<p><img decoding=\"async\" src=\"https:\/\/rasanegar.com\/blog\/wp-content\/uploads\/2024\/01\/guide-to-getting-started-with-nextjs-create-a-nextjs-app-6.png\" alt=\"\u062a\u0627\u0631\u06cc\u062e page\" 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>Next.js \u06cc\u06a9 \u0686\u0627\u0631\u0686\u0648\u0628 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0627\u0633\u062a \u06a9\u0647 \u0628\u0647 \u0637\u0648\u0631 \u062e\u0627\u0635 \u0628\u0631\u0627\u06cc \u0628\u0647\u0628\u0648\u062f \u0648 \u062a\u0642\u0648\u06cc\u062a \u062a\u0648\u0633\u0639\u0647 \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06a9\u0627\u0631\u0628\u0631\u062f\u06cc React \u0637\u0631\u0627\u062d\u06cc \u0634\u062f\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0631\u0627\u0647\u0646\u0645\u0627\u060c \u0648\u06cc\u0698\u06af\u06cc\u200c\u0647\u0627\u06cc \u0645\u0631\u0628\u0648\u0637 \u0628\u0647 \u06a9\u062a\u0627\u0628\u062e\u0627\u0646\u0647 \u0631\u0627 \u0628\u0631\u0631\u0633\u06cc \u06a9\u0631\u062f\u0647\u200c\u0627\u06cc\u0645 &#8211; \u0631\u0648\u0634 \u0627\u06cc\u062c\u0627\u062f \u0648 \u0645\u0633\u06cc\u0631\u06cc\u0627\u0628\u06cc \u0635\u0641\u062d\u0627\u062a \u0627\u0632 \u0637\u0631\u06cc\u0642 Next.js. <em>\u0633\u06cc\u0633\u062a\u0645 \u0645\u0633\u06cc\u0631\u06cc\u0627\u0628\u06cc \u0641\u0627\u06cc\u0644<\/em>\u060c \u0686\u06af\u0648\u0646\u0647 <code>&lt;Link&gt;<\/code> \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f\u060c \u0648\u0627\u06a9\u0634\u06cc \u0627\u0648\u0644\u06cc\u0647 \u0648 \u067e\u06cc\u0634 \u0631\u0646\u062f\u0631 \u0686\u06cc\u0633\u062a \u0648 \u0686\u06af\u0648\u0646\u0647 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0627\u0632 \u0622\u0646 \u0628\u0631\u0627\u06cc \u0628\u0647\u0628\u0648\u062f \u062a\u062c\u0631\u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0631\u062f\u060c \u0686\u06af\u0648\u0646\u0647 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc API \u0648 \u06a9\u0646\u062a\u0631\u0644 \u06a9\u0646\u0646\u062f\u0647 \u0647\u0627\u06cc \u062f\u0631\u062e\u0648\u0627\u0633\u062a \u0631\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646 \u0628\u0647 \u0631\u0627\u062d\u062a\u06cc \u0627\u06cc\u062c\u0627\u062f \u06a9\u0631\u062f \u0648 \u0686\u06af\u0648\u0646\u0647 \u0628\u0627 \u0645\u062a\u063a\u06cc\u0631\u0647\u0627\u06cc \u0645\u062d\u06cc\u0637 \u06a9\u0627\u0631 \u06a9\u0631\u062f.<\/p>\n<p>\u0628\u0631\u0627\u06cc \u062a\u06a9\u0645\u06cc\u0644 \u0622\u0646 &#8211; \u0645\u0627 \u06cc\u06a9 \u0628\u0631\u0646\u0627\u0645\u0647 \u0622\u0628 \u0648 \u0647\u0648\u0627 \u0633\u0627\u062e\u062a\u06cc\u0645 \u06a9\u0647 \u0628\u0627 API\u0647\u0627\u06cc \u062e\u0627\u0631\u062c\u06cc \u0627\u0631\u062a\u0628\u0627\u0637 \u0628\u0631\u0642\u0631\u0627\u0631 \u0645\u06cc \u06a9\u0646\u062f \u062a\u0627 \u062f\u0627\u062f\u0647 \u0647\u0627 \u0631\u0627 \u0648\u0627\u06a9\u0634\u06cc \u06a9\u0631\u062f\u0647 \u0648 \u0628\u0647 \u06a9\u0627\u0631\u0628\u0631 \u0646\u0647\u0627\u06cc\u06cc \u0646\u0645\u0627\u06cc\u0634 \u062f\u0647\u062f\u060c \u0648 \u0628\u0647 \u0622\u0646\u0647\u0627 \u0627\u062c\u0627\u0632\u0647 \u0645\u06cc \u062f\u0647\u062f \u0647\u0631 \u0645\u0647\u0631 \u0632\u0645\u0627\u0646\u06cc \u0645\u0639\u06cc\u0646\u06cc \u0631\u0627 \u062f\u0631 \u062d\u0627\u0641\u0638\u0647 \u0645\u062d\u0644\u06cc \u062e\u0648\u062f \u0630\u062e\u06cc\u0631\u0647 \u06a9\u0646\u0646\u062f.<\/p>\n<p>\u0628\u0627\u0632 \u0647\u0645\u060c \u06a9\u062f \u0645\u0646\u0628\u0639 \u06a9\u0627\u0645\u0644 \u0628\u0631\u0646\u0627\u0645\u0647 \u062f\u0631 \u062f\u0633\u062a\u0631\u0633 \u0627\u0633\u062a \u0631\u0648\u06cc <a target=\"_blank\" href=\"https:\/\/github.com\/StackAbuse\/weather-app\" rel=\"noopener\">GitHub<\/a>.<\/p>\n<\/div>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-13 13:58:06<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;15529&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\u0627\u0647\u0646\u0645\u0627\u06cc \u0634\u0631\u0648\u0639 \u0628\u0647 \u06a9\u0627\u0631 \u0628\u0627 Next.js - \u0627\u06cc\u062c\u0627\u062f \u06cc\u06a9 Next.js AppNext.js \u06cc\u06a9 \u0686\u0627\u0631\u0686\u0648\u0628 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0645\u0646\u0628\u0639 \u0628\u0627\u0632 \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0637 Vercel \u0628\u0631\u0627\u06cc \u0628\u0647\u0628\u0648\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc React \u0628\u0627 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f \u0631\u0646\u062f\u0631 \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0648 \u062a\u0648\u0644\u06cc\u062f \u0633\u0627\u06cc\u062a \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9 \u0627\u06cc\u062c\u0627\u062f \u0634\u062f\u0647 \u0627\u0633\u062a.  \u0628\u0647 \u0637\u0648\u0631 \u0633\u0646\u062a\u06cc\u060c React \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u06cc\u06a9 \u0635\u0641\u062d\u0647 \u0627\u06cc (SPA) \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f \u06a9\u0647 \u0645\u062d\u062a\u0648\u0627\u06cc \u0622\u0646\u0647\u0627 \u0631\u0646\u062f\u0631 \u0645\u06cc \u0634\u0648\u062f. \u0631\u0648\u06cc \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc  Next.js \u0628\u0627 \u0627\u062c\u0627\u0632\u0647 \u062f\u0627\u062f\u0646 \u0628\u0647 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u06af\u0627\u0646 \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f...&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\"> 15<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0645\u0639\u0631\u0641\u06cc Next.js \u06cc\u06a9 \u0686\u0627\u0631\u0686\u0648\u0628 \u062c\u0627\u0648\u0627 \u0627\u0633\u06a9\u0631\u06cc\u067e\u062a \u0645\u0646\u0628\u0639 \u0628\u0627\u0632 \u0627\u0633\u062a \u06a9\u0647 \u062a\u0648\u0633\u0637 Vercel \u0628\u0631\u0627\u06cc \u0628\u0647\u0628\u0648\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc React \u0628\u0627 \u0648\u06cc\u0698\u06af\u06cc \u0647\u0627\u06cc\u06cc \u0645\u0627\u0646\u0646\u062f \u0631\u0646\u062f\u0631 \u0633\u0645\u062a \u0633\u0631\u0648\u0631 \u0648 \u062a\u0648\u0644\u06cc\u062f \u0633\u0627\u06cc\u062a \u0627\u0633\u062a\u0627\u062a\u06cc\u06a9. \u0628\u0647 \u0637\u0648\u0631 \u0633\u0646\u062a\u06cc\u060c React \u0628\u0631\u0627\u06cc \u0627\u06cc\u062c\u0627\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u062a\u06a9 \u0635\u0641\u062d\u0647 \u0627\u06cc (SPA) \u06a9\u0647 \u0645\u0637\u0627\u0644\u0628 \u0622\u0646 \u0627\u0631\u0627\u0626\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0631\u0648\u06cc \u0633\u0645\u062a \u0645\u0634\u062a\u0631\u06cc Next.js \u0628\u0627 \u0627\u062c\u0627\u0632\u0647 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":15530,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[4021,1827,1828,1209,4022,1100,3562,4023,2508,2103,4024,1811,2501,1786,1781,2051,1936,1779,1954,1814,1909,1841,1807,3412,3384,1881,3125,1780,1103,3653,2416,1882,1759,3442,2667,3358,115,1859,2842,2121,2097,2015,2264,2376,2820,1956,1795,1979,3359,3462,1953,1790,1966,2322,2408,1785,1978,2446,1813],"class_list":["post-15529","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","category-programming","tag-next-js","tag-react","tag-1828","tag-api","tag-appnext-js","tag-javascript","tag-spa","tag-vercel","tag--javascript","tag-2103","tag-4024","tag-1811","tag-2501","tag-1786","tag-1781","tag-2051","tag-1936","tag-1779","tag-1954","tag-1814","tag-1909","tag-1841","tag-1807","tag-3412","tag-3384","tag-1881","tag-3125","tag-1780","tag-1103","tag-3653","tag-2416","tag-1882","tag-1759","tag-3442","tag-2667","tag-3358","tag-115","tag---nodejs","tag-2842","tag-2121","tag-2097","tag-2015","tag-2264","tag-2376","tag-2820","tag-1956","tag-1795","tag-1979","tag-3359","tag-3462","tag-1953","tag-1790","tag--javascrip","tag-2322","tag-2408","tag-1785","tag-1978","tag-2446","tag-1813"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15529","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=15529"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15529\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/15530"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=15529"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=15529"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=15529"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}