{"id":15309,"date":"2024-01-11T01:04:09","date_gmt":"2024-01-10T21:34:09","guid":{"rendered":"https:\/\/rasanegar.com\/blog\/%d8%aa%d8%ba%db%8c%db%8c%d8%b1-%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7-%d8%af%d8%b1-react-router-%d8%a7%da%af%d8%b1-%d8%aa%d9%88%d8%b3%d8%b9%d9%87-%d8%af%d9%87%d9%86%d8%af%d9%87-%d8%a7%db%8c-%d9%87%d8%b3\/"},"modified":"2024-01-11T01:04:09","modified_gmt":"2024-01-10T21:34:09","slug":"%d8%aa%d8%ba%db%8c%db%8c%d8%b1-%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7-%d8%af%d8%b1-react-router-%d8%a7%da%af%d8%b1-%d8%aa%d9%88%d8%b3%d8%b9%d9%87-%d8%af%d9%87%d9%86%d8%af%d9%87-%d8%a7%db%8c-%d9%87%d8%b3","status":"publish","type":"post","link":"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%ba%db%8c%db%8c%d8%b1-%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7-%d8%af%d8%b1-react-router-%d8%a7%da%af%d8%b1-%d8%aa%d9%88%d8%b3%d8%b9%d9%87-%d8%af%d9%87%d9%86%d8%af%d9%87-%d8%a7%db%8c-%d9%87%d8%b3\/","title":{"rendered":"\u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627 \u062f\u0631 React Router \u0627\u06af\u0631 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 \u0627\u06cc \u0647\u0633\u062a\u06cc\u062f \u06a9\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u0647\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646\u060c \u0627\u062d\u062a\u0645\u0627\u0644\u0627\u064b \u0627\u0632 \u0627\u0647\u0645\u06cc\u062a \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0635\u062d\u06cc\u062d \u0645\u0633\u06cc\u0631\u06cc\u0627\u0628\u06cc \u0622\u06af\u0627\u0647 \u0647\u0633\u062a\u06cc\u062f.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0622\u0645\u0648\u0632\u0634\u200c\u0647\u0627\u06cc React Router \u0631\u0627 \u0645\u0631\u0648\u0631 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u062f\u060c \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0645\u062a\u0648\u062c\u0647 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0628\u0647 \u0646\u062f\u0631\u062a \u0628\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627 \u0627\u0634\u0627\u0631\u0647 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f \u0648 \u062f\u0631 \u0639\u0648\u0636 \u062a\u0645\u0631\u06a9\u0632 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. \u0631\u0648\u06cc \u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0644\u06cc\u0646\u06a9  \u0628\u0647&#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%aa%d8%ba%db%8c%db%8c%d8%b1-%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7-%d8%af%d8%b1-react-router-%d8%a7%da%af%d8%b1-%d8%aa%d9%88%d8%b3%d8%b9%d9%87-%d8%af%d9%87%d9%86%d8%af%d9%87-%d8%a7%db%8c-%d9%87%d8%b3\/#%d9%85%d8%b9%d8%b1%d9%81%db%8c\" >\u0645\u0639\u0631\u0641\u06cc<\/a><ul class='ez-toc-list-level-3' ><li class='ez-toc-heading-level-3'><a class=\"ez-toc-link ez-toc-heading-2\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%ba%db%8c%db%8c%d8%b1-%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7-%d8%af%d8%b1-react-router-%d8%a7%da%af%d8%b1-%d8%aa%d9%88%d8%b3%d8%b9%d9%87-%d8%af%d9%87%d9%86%d8%af%d9%87-%d8%a7%db%8c-%d9%87%d8%b3\/#%d9%be%db%8c%d8%b4_%d9%86%db%8c%d8%a7%d8%b2%d9%87%d8%a7\" >\u067e\u06cc\u0634 \u0646\u06cc\u0627\u0632\u0647\u0627<\/a><\/li><\/ul><\/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%aa%d8%ba%db%8c%db%8c%d8%b1-%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7-%d8%af%d8%b1-react-router-%d8%a7%da%af%d8%b1-%d8%aa%d9%88%d8%b3%d8%b9%d9%87-%d8%af%d9%87%d9%86%d8%af%d9%87-%d8%a7%db%8c-%d9%87%d8%b3\/#%d8%aa%d8%ba%db%8c%db%8c%d8%b1_%d9%85%d8%b3%db%8c%d8%b1_%d9%88_%d9%be%db%8c%d9%85%d8%a7%db%8c%d8%b4_%da%a9%d8%a7%d9%85%d9%be%d9%88%d9%86%d9%86%d8%aa\" >\u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631 \u0648 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a<\/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%aa%d8%ba%db%8c%db%8c%d8%b1-%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7-%d8%af%d8%b1-react-router-%d8%a7%da%af%d8%b1-%d8%aa%d9%88%d8%b3%d8%b9%d9%87-%d8%af%d9%87%d9%86%d8%af%d9%87-%d8%a7%db%8c-%d9%87%d8%b3\/#%d8%aa%d8%ba%db%8c%db%8c%d8%b1_%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c_%d9%85%d8%b4%d8%b1%d9%88%d8%b7\" >\u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0645\u0634\u0631\u0648\u0637<\/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%aa%d8%ba%db%8c%db%8c%d8%b1-%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7-%d8%af%d8%b1-react-router-%d8%a7%da%af%d8%b1-%d8%aa%d9%88%d8%b3%d8%b9%d9%87-%d8%af%d9%87%d9%86%d8%af%d9%87-%d8%a7%db%8c-%d9%87%d8%b3\/#%d8%ac%d8%a7%db%8c%da%af%d8%b2%db%8c%d9%86_%da%a9%d8%b1%d8%af%d9%86_url_%d9%81%d8%b9%d9%84%db%8c\" >\u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u06a9\u0631\u062f\u0646 URL \u0641\u0639\u0644\u06cc<\/a><\/li><\/ul><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-6\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%ba%db%8c%db%8c%d8%b1-%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7-%d8%af%d8%b1-react-router-%d8%a7%da%af%d8%b1-%d8%aa%d9%88%d8%b3%d8%b9%d9%87-%d8%af%d9%87%d9%86%d8%af%d9%87-%d8%a7%db%8c-%d9%87%d8%b3\/#%d8%aa%d8%ba%db%8c%db%8c%d8%b1_%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c_%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87_%d8%a7%db%8c_%d8%a8%d8%a7_usenavigate\" >\u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u06cc \u0628\u0627 useNavigate()<\/a><\/li><li class='ez-toc-page-1 ez-toc-heading-level-2'><a class=\"ez-toc-link ez-toc-heading-7\" href=\"https:\/\/rasanegaar.com\/blog\/%d8%aa%d8%ba%db%8c%db%8c%d8%b1-%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7-%d8%af%d8%b1-react-router-%d8%a7%da%af%d8%b1-%d8%aa%d9%88%d8%b3%d8%b9%d9%87-%d8%af%d9%87%d9%86%d8%af%d9%87-%d8%a7%db%8c-%d9%87%d8%b3\/#%d9%86%d8%aa%db%8c%d8%ac%d9%87\" >\u0646\u062a\u06cc\u062c\u0647<\/a><\/li><\/ul><\/nav><\/div>\n<span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 4<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span><p> <br \/>\n<\/p>\n<div class=\"content\"><noscript><\/p>\n<style>.lazyload-placeholder { display: none;  }<\/style>\n<p><\/noscript><\/p>\n<h2 id=\"introduction\"><span class=\"ez-toc-section\" id=\"%d9%85%d8%b9%d8%b1%d9%81%db%8c\"><\/span>\u0645\u0639\u0631\u0641\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u06af\u0631 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 \u0627\u06cc \u0647\u0633\u062a\u06cc\u062f \u06a9\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u0647\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646\u060c \u0627\u062d\u062a\u0645\u0627\u0644\u0627\u064b \u0627\u0632 \u0627\u0647\u0645\u06cc\u062a \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0635\u062d\u06cc\u062d \u0645\u0633\u06cc\u0631\u06cc\u0627\u0628\u06cc \u0622\u06af\u0627\u0647 \u0647\u0633\u062a\u06cc\u062f.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0622\u0645\u0648\u0632\u0634\u200c\u0647\u0627\u06cc React Router \u0631\u0627 \u0645\u0631\u0648\u0631 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u062f\u060c \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0645\u062a\u0648\u062c\u0647 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0628\u0647 \u0646\u062f\u0631\u062a \u0628\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627 \u0627\u0634\u0627\u0631\u0647 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f \u0648 \u062f\u0631 \u0639\u0648\u0636 \u062a\u0645\u0631\u06a9\u0632 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. \u0631\u0648\u06cc \u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>Link<\/code> \u062c\u0632\u0621.  \u0628\u0631\u0627\u06cc \u0645\u062f\u06cc\u0631\u06cc\u062a \u0645\u0633\u06cc\u0631\u06cc\u0627\u0628\u06cc \u062f\u0631 React\u060c \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645 <a rel=\"nofollow noopener\" target=\"_blank\" href=\"https:\/\/www.npmjs.com\/package\/react-router-dom\">react-router-dom<\/a> \u0628\u0633\u062a\u0647 \u0628\u0646\u062f\u06cc<\/p>\n<blockquote>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u067e\u0633\u062a\u060c \u0631\u0648\u0634\u200c\u0647\u0627 \u0648 \u0633\u0646\u0627\u0631\u06cc\u0648\u0647\u0627\u06cc \u0632\u06cc\u0627\u062f\u06cc \u0631\u0627 \u06a9\u0647 \u062f\u0631 \u0622\u0646\u200c\u0647\u0627 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u062f \u0627\u0632 \u0631\u06cc\u062f\u0627\u06cc\u0631\u06a9\u062a\u200c\u0647\u0627 \u062f\u0631 React \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f\u060c \u0628\u0631\u0631\u0633\u06cc \u0645\u06cc\u200c\u06a9\u0646\u06cc\u0645.  \u0645\u0627 \u0647\u0645\u0686\u0646\u06cc\u0646 \u0628\u0647 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0627\u0633\u062a\u0631\u0627\u062a\u0698\u06cc \u0647\u0627\u06cc \u0642\u0628\u0644\u06cc \u0648 \u0631\u0648\u0634 \u0639\u0645\u0644\u06a9\u0631\u062f \u0622\u0646\u0647\u0627 \u0628\u0627 \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u0647\u0627\u06cc \u062c\u062f\u06cc\u062f \u0628\u0631\u0627\u06cc \u0622\u0646\u0647\u0627 \u062f\u0631 React Router v6 \u06a9\u0647 \u062c\u062f\u06cc\u062f\u062a\u0631\u06cc\u0646 \u0646\u0633\u062e\u0647 \u062a\u0627 \u0632\u0645\u0627\u0646 \u0646\u06af\u0627\u0631\u0634 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647 \u0627\u0633\u062a \u0646\u06af\u0627\u0647 \u062e\u0648\u0627\u0647\u06cc\u0645 \u06a9\u0631\u062f.<\/p>\n<\/blockquote>\n<h3 id=\"prerequisites\"><span class=\"ez-toc-section\" id=\"%d9%be%db%8c%d8%b4_%d9%86%db%8c%d8%a7%d8%b2%d9%87%d8%a7\"><\/span>\u067e\u06cc\u0634 \u0646\u06cc\u0627\u0632\u0647\u0627<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u0642\u0627\u0644\u0647 \u0627\u0632 <code>react-router-dom<\/code> \u0628\u0633\u062a\u0647 \u0627\u06cc \u06a9\u0647 \u0628\u0627\u06cc\u062f \u062f\u0631 \u067e\u0631\u0648\u0698\u0647 \u062e\u0648\u062f \u0646\u0635\u0628 \u06a9\u0646\u06cc\u0645.  \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0628\u0627 \u0627\u062c\u0631\u0627\u06cc \u06cc\u06a9\u06cc \u0627\u0632 \u062f\u0633\u062a\u0648\u0631\u0627\u062a \u0632\u06cc\u0631 \u062f\u0631 \u0645\u0627 \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u0634\u0648\u062f terminal:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> npm i react-router-dom<\/span>\n<\/code><\/pre>\n<p>\u06cc\u0627<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-meta\">$<\/span><span class=\"bash\"> yarn add react-router-dom<\/span>\n<\/code><\/pre>\n<h2 id=\"redirectandnavigatecomponent\"><span class=\"ez-toc-section\" id=\"%d8%aa%d8%ba%db%8c%db%8c%d8%b1_%d9%85%d8%b3%db%8c%d8%b1_%d9%88_%d9%be%db%8c%d9%85%d8%a7%db%8c%d8%b4_%da%a9%d8%a7%d9%85%d9%be%d9%88%d9%86%d9%86%d8%aa\"><\/span>\u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631 \u0648 \u067e\u06cc\u0645\u0627\u06cc\u0634 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0627\u06cc\u0646 <code>Redirect<\/code> \u062c\u0632\u0621 \u0645\u0639\u0645\u0648\u0644\u0627 \u062f\u0631 \u0646\u0633\u062e\u0647 \u0647\u0627\u06cc \u0642\u0628\u0644\u06cc \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u062f <code>react-router-dom<\/code> \u0628\u0633\u062a\u0647 \u0627\u06cc \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0633\u0631\u06cc\u0639 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627 \u0628\u0627 \u0648\u0627\u0631\u062f \u06a9\u0631\u062f\u0646 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0627\u0632 \u0622\u0646 <code>react-router-dom<\/code> \u0648 \u0633\u067e\u0633 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u062c\u0632\u0621 \u0628\u0627 \u0627\u0631\u0627\u0626\u0647 <code>to<\/code> \u062a\u06a9\u06cc\u0647 \u06af\u0627\u0647\u060c \u0639\u0628\u0648\u0631 \u0627\u0632 page \u0634\u0645\u0627 \u0645\u0627\u06cc\u0644 \u0628\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631 \u0628\u0647.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { Redirect } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'react-router-dom'<\/span>;\n\n<span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Route<\/span> <span class=\"hljs-attr\">path<\/span>=<span class=\"hljs-string\">'\/redirect-page'<\/span> <span class=\"hljs-attr\">element<\/span>=<span class=\"hljs-string\">{<\/span> &lt;<span class=\"hljs-attr\">Redirect<\/span> <span class=\"hljs-attr\">to<\/span>=<span class=\"hljs-string\">\"\/error-page\"<\/span> \/&gt;<\/span> }\/&gt;<\/span>\n<\/code><\/pre>\n<p>\u0628\u0627 \u0627\u0646\u062a\u0634\u0627\u0631 React Router v6\u060c <code>Redirect<\/code> \u062c\u0632\u0621 \u062d\u0630\u0641 \u0634\u062f \u0648 \u0628\u0627 <code>Navigate<\/code> \u062c\u0632\u0621\u060c \u06a9\u0647 \u062f\u0631\u0633\u062a \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 <code>Redirect<\/code> \u062c\u0632\u0621 \u0628\u0627 \u062f\u0631 \u0646\u0638\u0631 \u06af\u0631\u0641\u062a\u0646 <code>to<\/code> prop \u062a\u0627 \u0634\u0645\u0627 \u0631\u0627 \u0642\u0627\u062f\u0631 \u0633\u0627\u0632\u062f \u062a\u0627 \u0628\u0647 page \u0634\u0645\u0627 \u0645\u0634\u062e\u0635 \u0645\u06cc \u06a9\u0646\u06cc\u062f<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { Navigate } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'react-router-dom'<\/span>;\n\n<span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Route<\/span> <span class=\"hljs-attr\">path<\/span>=<span class=\"hljs-string\">\"\/redirect\"<\/span> <span class=\"hljs-attr\">element<\/span>=<span class=\"hljs-string\">{<\/span> &lt;<span class=\"hljs-attr\">Navigate<\/span> <span class=\"hljs-attr\">to<\/span>=<span class=\"hljs-string\">\"\/error-page\"<\/span> \/&gt;<\/span> } \/&gt;<\/span>\n<\/code><\/pre>\n<p><em>\u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0627\u0632 \u0642\u0628\u0644 \u0645\u0633\u06cc\u0631 \u0631\u0627 \u062f\u0627\u0631\u06cc\u062f<\/em>.  \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u0628\u0647 &#8220;\/error- \u0647\u062f\u0627\u06cc\u062a \u0634\u0648\u06cc\u062f.page\u0645\u0633\u06cc\u0631\u060c \u0645\u0637\u0645\u0626\u0646 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0642\u0628\u0644\u0627\u064b \u0645\u0633\u06cc\u0631 \u0631\u0627 \u0627\u0639\u0644\u0627\u0645 \u06a9\u0631\u062f\u0647 \u0627\u06cc\u062f <em>\u0642\u0628\u0644 \u0627\u0632<\/em> \u062a\u0646\u0638\u06cc\u0645 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631  \u0628\u0647 \u0633\u0641\u0627\u0631\u0634 \u062a\u0648\u062c\u0647 \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u062f \u06cc\u0627 <code>Route<\/code> \u0627\u0639\u0644\u0627\u0645\u06cc\u0647 \u062f\u0631 \u06a9\u062f \u0632\u06cc\u0631:<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { BrowserRouter, Routes, Route, Navigate } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'react-router-dom'<\/span>;\n<span class=\"hljs-keyword\">import<\/span> ErrorPage <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'.\/ErrorPage'<\/span>;\n<span class=\"hljs-keyword\">import<\/span> Home <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'.\/Home'<\/span>;\n\n<span class=\"hljs-function\"><span class=\"hljs-keyword\">function<\/span> <span class=\"hljs-title\">App<\/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\">BrowserRouter<\/span>&gt;<\/span>\n            <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Routes<\/span>&gt;<\/span>\n                <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Route<\/span>\n                    <span class=\"hljs-attr\">path<\/span>=<span class=\"hljs-string\">\"\/\"<\/span>\n                    <span class=\"hljs-attr\">element<\/span>=<span class=\"hljs-string\">{<\/span> &lt;<span class=\"hljs-attr\">Home<\/span> \/&gt;<\/span> }\n                \/&gt;\n                {\/* The next line is very important for the Navigate component to work *\/}\n                <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Route<\/span>\n                    <span class=\"hljs-attr\">path<\/span>=<span class=\"hljs-string\">\"\/error-page\"<\/span>\n                    <span class=\"hljs-attr\">element<\/span>=<span class=\"hljs-string\">{<\/span> &lt;<span class=\"hljs-attr\">ErrorPage<\/span> \/&gt;<\/span> }\n                \/&gt;\n                <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Route<\/span>\n                    <span class=\"hljs-attr\">path<\/span>=<span class=\"hljs-string\">\"\/redirect\"<\/span>\n                    <span class=\"hljs-attr\">element<\/span>=<span class=\"hljs-string\">{<\/span> &lt;<span class=\"hljs-attr\">Navigate<\/span> <span class=\"hljs-attr\">to<\/span>=<span class=\"hljs-string\">\"\/error-page\"<\/span> \/&gt;<\/span> }\n                \/&gt;\n            <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">Routes<\/span>&gt;<\/span>\n        <span class=\"hljs-tag\">&lt;\/<span class=\"hljs-name\">BrowserRouter<\/span>&gt;<\/span><\/span>\n    );\n}\n<span class=\"hljs-keyword\">export<\/span> <span class=\"hljs-keyword\">default<\/span> App;\n<\/code><\/pre>\n<h3 id=\"conditionalredirects\"><span class=\"ez-toc-section\" id=\"%d8%aa%d8%ba%db%8c%db%8c%d8%b1_%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c_%d9%85%d8%b4%d8%b1%d9%88%d8%b7\"><\/span>\u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0645\u0634\u0631\u0648\u0637<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u0627\u06cc\u0646 \u0686\u06cc\u0632\u06cc \u0627\u0633\u062a \u06a9\u0647 \u0627\u062d\u062a\u0645\u0627\u0644\u0627\u064b \u0628\u0627\u06cc\u062f \u0647\u0646\u06af\u0627\u0645 \u0633\u0627\u062e\u062a \u0628\u0631\u0646\u0627\u0645\u0647 \u0647\u0627\u06cc \u0648\u0628 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u062f.  \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0645\u0634\u0631\u0648\u0637 \u0628\u0647 \u0633\u0627\u062f\u06af\u06cc \u0645\u0628\u062a\u0646\u06cc \u0628\u0631 \u0645\u0633\u06cc\u0631\u06cc\u0627\u0628\u06cc \u0647\u0633\u062a\u0646\u062f \u0631\u0648\u06cc \u0645\u0639\u06cc\u0627\u0631\u0647\u0627\u06cc \u062e\u0627\u0635<\/p>\n<p>\u06cc\u06a9 \u0633\u0646\u0627\u0631\u06cc\u0648\u06cc \u0645\u062a\u062f\u0627\u0648\u0644 \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0632\u0645\u0627\u0646\u06cc \u0628\u0627\u0634\u062f \u06a9\u0647 \u0634\u0645\u0627 \u062f\u0631 \u062d\u0627\u0644 \u0633\u0627\u062e\u062a\u0646 \u06cc\u06a9 \u067e\u0644\u062a\u0641\u0631\u0645 \u062a\u062c\u0627\u0631\u062a \u0627\u0644\u06a9\u062a\u0631\u0648\u0646\u06cc\u06a9 \u0647\u0633\u062a\u06cc\u062f \u0648 \u0646\u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0628\u0647 \u0627\u062c\u0632\u0627\/\u0645\u0648\u0627\u062f\/\u0641\u0631\u0645 \u0647\u0627\u06cc \u062e\u0627\u0635\u06cc \u0645\u0627\u0646\u0646\u062f \u0645\u0648\u062f\u0627\u0644\/\u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u067e\u0631\u062f\u0627\u062e\u062a\u060c \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u0646\u062f \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0628\u0631\u062e\u06cc \u0627\u0632 \u0645\u062d\u0635\u0648\u0644\u0627\u062a \u0631\u0627 \u0628\u0647 \u0622\u0646 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u0646\u062f. \u0633\u0628\u062f \u062e\u0631\u06cc\u062f  \u0627\u06af\u0631 \u0628\u062e\u0648\u0627\u0647\u0646\u062f \u0628\u0647 \u0632\u0648\u0631 \u0631\u0627\u0647\u0634\u0627\u0646 \u0631\u0627 \u0648\u0627\u0631\u062f \u06a9\u0646\u0646\u062f page\u060c \u0622\u0646\u0647\u0627 \u0628\u0627\u06cc\u062f \u0628\u0647 \u0645\u062d\u0635\u0648\u0644\u0627\u062a \u0647\u062f\u0627\u06cc\u062a \u0634\u0648\u0646\u062f page \u0628\u0646\u0627\u0628\u0631\u0627\u06cc\u0646 \u0622\u0646\u0647\u0627 \u0645\u06cc \u062a\u0648\u0627\u0646\u0646\u062f \u0627\u0628\u062a\u062f\u0627 \u0645\u0648\u0627\u0631\u062f \u0631\u0627 \u0627\u0646\u062a\u062e\u0627\u0628 \u06a9\u0646\u0646\u062f.<\/p>\n<p>\u0627\u06cc\u0646 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0645\u0634\u0631\u0648\u0637 \u0634\u0646\u0627\u062e\u062a\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0627\u0632 <code>useState()<\/code> hook  \u062a\u0627 \u0622\u0631\u0627\u06cc\u0647 \u0633\u0628\u062f \u062e\u0631\u06cc\u062f \u0631\u0627 \u062e\u0627\u0644\u06cc \u06a9\u0646\u06cc\u0645 \u0648 \u0633\u067e\u0633 \u0645\u0639\u06cc\u0627\u0631\u0647\u0627\u06cc\u06cc \u0631\u0627 \u062f\u0631 \u0645\u0633\u06cc\u0631 \u062e\u0648\u062f \u0627\u0639\u0645\u0627\u0644 \u06a9\u0646\u06cc\u0645.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">const<\/span> (cartItems, setCartItems) = useState(());\n\n<span class=\"xml\"><span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Route<\/span>\n    <span class=\"hljs-attr\">path<\/span>=<span class=\"hljs-string\">\"\/checkout\"<\/span>\n    <span class=\"hljs-attr\">element<\/span>=<span class=\"hljs-string\">{<\/span> <span class=\"hljs-attr\">cartItems.length<\/span> &lt; <span class=\"hljs-attr\">1<\/span> ? &lt;<span class=\"hljs-attr\">Navigate<\/span> <span class=\"hljs-attr\">to<\/span>=<span class=\"hljs-string\">\"\/products\"<\/span> \/&gt;<\/span> : <span class=\"hljs-tag\">&lt;<span class=\"hljs-name\">Checkout<\/span> \/&gt;<\/span> }\n\/&gt;<\/span>;\n<\/code><\/pre>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u0645\u062b\u0627\u0644\u060c \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u0627\u06cc\u0646 \u0622\u0631\u0627\u06cc\u0647 \u062e\u0627\u0644\u06cc \u0628\u0627\u0634\u062f\u060c \u0645\u0627 \u0646\u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0628\u0647 \u0622\u0646 \u062f\u0633\u062a\u0631\u0633\u06cc \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u06cc\u0645 <code>\/checkout<\/code> \u0645\u0633\u06cc\u0631 \u062a\u0627 \u0632\u0645\u0627\u0646\u06cc \u06a9\u0647 \u062d\u062f\u0627\u0642\u0644 \u06cc\u06a9 \u0645\u0648\u0631\u062f \u062f\u0631 \u0622\u0646 \u0648\u062c\u0648\u062f \u062f\u0627\u0634\u062a\u0647 \u0628\u0627\u0634\u062f <code>cartItems<\/code> \u0622\u0631\u0627\u06cc\u0647.<\/p>\n<h3 id=\"replacingthecurrenturl\"><span class=\"ez-toc-section\" id=\"%d8%ac%d8%a7%db%8c%da%af%d8%b2%db%8c%d9%86_%da%a9%d8%b1%d8%af%d9%86_url_%d9%81%d8%b9%d9%84%db%8c\"><\/span>\u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u06a9\u0631\u062f\u0646 URL \u0641\u0639\u0644\u06cc<span class=\"ez-toc-section-end\"><\/span><\/h3>\n<p>\u062f\u0631 \u0628\u0631\u062e\u06cc \u0645\u0648\u0627\u0631\u062f\u060c \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u062e\u0648\u0627\u0647\u06cc\u062f \u0628\u0647 \u062c\u0627\u06cc \u0627\u0641\u0632\u0648\u062f\u0646 (\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644\u060c \u0641\u0634\u0627\u0631 \u062f\u0627\u062f\u0646) \u0622\u0646 \u0628\u0647 \u062a\u0627\u0631\u06cc\u062e\u0686\u0647 \u0645\u0631\u0648\u0631\u06af\u0631 \u062e\u0648\u062f\u060c URL \u0641\u0639\u0644\u06cc \u0631\u0627 \u062f\u0631 \u0645\u0631\u0648\u0631\u06af\u0631 \u062c\u0627\u06cc\u06af\u0632\u06cc\u0646 \u06a9\u0646\u06cc\u062f\u060c \u0628\u0631\u0627\u06cc \u0627\u0646\u062c\u0627\u0645 \u0627\u06cc\u0646 \u06a9\u0627\u0631 \u0645\u0627 \u0641\u0642\u0637 \u0628\u0627\u06cc\u062f URL \u0631\u0627 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u0645. <code>replace<\/code> \u062a\u06a9\u06cc\u0647 \u06af\u0627\u0647 \u0628\u0647 <code>Navigate<\/code> \u062c\u0632\u0621.<\/p>\n<pre><code class=\"hljs\">&lt;Navigate replace to=<span class=\"hljs-string\">\"\/error-page\"<\/span> \/&gt;\n<\/code><\/pre>\n<p>\u0628\u062f\u0648\u0646 \u0627\u06cc\u0646 \u067e\u0634\u062a\u06cc\u0628\u0627\u0646\u06cc\u060c \u0645\u0631\u0648\u0631\u06af\u0631 \u062a\u0627\u0631\u06cc\u062e\u0686\u0647\u060c \u0627\u0632 \u062c\u0645\u0644\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631 \u0631\u0627 \u067e\u06cc\u06af\u06cc\u0631\u06cc \u0645\u06cc \u06a9\u0646\u062f.<\/p>\n<h2 id=\"programmaticredirectswithusenavigate\"><span class=\"ez-toc-section\" id=\"%d8%aa%d8%ba%db%8c%db%8c%d8%b1_%d9%85%d8%b3%db%8c%d8%b1%d9%87%d8%a7%db%8c_%d8%a8%d8%b1%d9%86%d8%a7%d9%85%d9%87_%d8%a7%db%8c_%d8%a8%d8%a7_usenavigate\"><\/span>\u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627\u06cc \u0628\u0631\u0646\u0627\u0645\u0647 \u0627\u06cc \u0628\u0627 <code>useNavigate()<\/code><span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0628\u0627 \u0622\u0646 \u0622\u0634\u0646\u0627 \u0628\u0627\u0634\u06cc\u062f <code>useHistory()<\/code> hook  \u0627\u0632 \u0646\u0633\u062e\u0647 \u0647\u0627\u06cc \u0642\u0628\u0644\u06cc <code>react-router-dom<\/code> \u0628\u0633\u062a\u0647\u060c \u06a9\u0647 \u0628\u0631\u0627\u06cc \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631 \u0628\u0631\u0646\u0627\u0645\u0647\u200c\u0646\u0648\u06cc\u0633\u06cc \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc\u200c\u0634\u062f.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0627\u0632\u062f\u06cc\u062f\u06a9\u0646\u0646\u062f\u06af\u0627\u0646 \u067e\u0631 \u06a9\u0631\u062f\u0646 \u06cc\u06a9 \u0641\u0631\u0645 \u0631\u0627 \u0628\u0647 \u067e\u0627\u06cc\u0627\u0646 \u0631\u0633\u0627\u0646\u062f\u0646\u062f\u060c \u06cc\u0627 \u0627\u06af\u0631 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u062f \u06cc\u06a9 \u062a\u0627\u0628\u0639 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631 \u0631\u0627 \u0628\u0647 \u06cc\u06a9 \u062f\u06a9\u0645\u0647 \u0627\u0636\u0627\u0641\u0647 \u06a9\u0646\u06cc\u062f\u060c \u0627\u06cc\u0646 \u06cc\u06a9 \u0645\u0648\u0631\u062f \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0639\u0627\u0644\u06cc \u0627\u0633\u062a.<\/p>\n<p>\u0627\u06cc\u0646 <code>useHistory()<\/code> hook  \u0627\u0628\u062a\u062f\u0627 \u0648\u0627\u0631\u062f \u0645\u06cc \u0634\u0648\u062f \u0648 \u0633\u067e\u0633 \u0628\u0647 \u06cc\u06a9 \u0645\u062a\u063a\u06cc\u0631 \u0627\u062e\u062a\u0635\u0627\u0635 \u0645\u06cc \u06cc\u0627\u0628\u062f\u060c \u06a9\u0647 \u0645\u062a\u0639\u0627\u0642\u0628\u0627\u064b \u062f\u0631 \u06cc\u06a9 \u062f\u06a9\u0645\u0647 (\u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u0645\u062b\u0627\u0644) \u0628\u0631\u0627\u06cc \u0647\u062f\u0627\u06cc\u062a \u0645\u062c\u062f\u062f \u06a9\u0627\u0631\u0628\u0631\u0627\u0646 \u067e\u0633 \u0627\u0632 \u0627\u0646\u062c\u0627\u0645 \u06cc\u06a9 \u0627\u0642\u062f\u0627\u0645 \u062e\u0627\u0635 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0645\u06cc \u0634\u0648\u062f.  \u0628\u0627 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 <code>onClick<\/code> \u0631\u0648\u06cc\u062f\u0627\u062f\u060c \u0633\u067e\u0633 \u0645\u06cc\u200c\u062a\u0648\u0627\u0646\u06cc\u0645 \u0622\u0646 \u0631\u0627 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u06a9\u0646\u06cc\u0645 <code>.push()<\/code> \u0631\u0648\u0634\u06cc \u0628\u0631\u0627\u06cc \u0627\u06cc\u0646\u06a9\u0647 \u0628\u0647 React Router \u0628\u06af\u0648\u06cc\u06cc\u0645 \u06a9\u0647 \u0645\u06cc \u062e\u0648\u0627\u0647\u06cc\u0645 \u062f\u06a9\u0645\u0647 \u0628\u0647 \u06a9\u062c\u0627 \u0647\u062f\u0627\u06cc\u062a \u0634\u0648\u062f.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { useHistory } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'react-router-dom'<\/span>;\n\n<span class=\"hljs-keyword\">const<\/span> Home = <span class=\"hljs-function\">() =&gt;<\/span> {\n    <span class=\"hljs-keyword\">const<\/span> history = useHistory();\n    <span class=\"hljs-keyword\">return<\/span> (\n        {<span class=\"hljs-comment\">\/* ... *\/<\/span>}\n        &lt;button onClick={<span class=\"hljs-function\">() =&gt;<\/span> history.push(<span class=\"hljs-string\">'\/products'<\/span>)}&gt;\n        {<span class=\"hljs-comment\">\/* ... *\/<\/span>}\n    );\n};\n<\/code><\/pre>\n<p>\u0628\u0627 \u0627\u0646\u062a\u0634\u0627\u0631 React Router v6\u060c \u062f\u06cc\u06af\u0631 \u0627\u0632 \u0622\u0646 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0646\u0645\u06cc \u06a9\u0646\u06cc\u0645 <code>useHistory()<\/code> hook\u060c \u0627\u0645\u0627 \u062f\u0631 \u0639\u0648\u0636 <code>useNavigate()<\/code> hook\u060c \u06a9\u0647 \u06a9\u0627\u0645\u0644\u0627 \u0645\u0634\u0627\u0628\u0647 \u0627\u0633\u062a.<\/p>\n<p>\u0627\u06cc\u0646 \u0646\u06cc\u0632 \u0628\u0627 \u0648\u0627\u0631\u062f\u0627\u062a \u0627\u0646\u062c\u0627\u0645 \u0645\u06cc \u0634\u0648\u062f hook \u0648 \u0633\u067e\u0633 \u06cc\u06a9 \u0645\u062a\u063a\u06cc\u0631 \u0628\u0647 <code>useNavigate()<\/code> hook\u060c \u0647\u0645\u0627\u0646\u0637\u0648\u0631 \u06a9\u0647 \u0645\u0627 \u0628\u0627 \u0622\u0646 \u0627\u0646\u062c\u0627\u0645 \u062f\u0627\u062f\u06cc\u0645 <code>useHistory()<\/code>.  \u0627\u06a9\u0646\u0648\u0646 \u0645\u06cc \u062a\u0648\u0627\u0646\u06cc\u0645 \u0627\u0632 \u0645\u062a\u063a\u06cc\u0631\u06cc \u06a9\u0647 \u0628\u0631\u06af\u0631\u062f\u0627\u0646\u062f\u0647 \u0634\u062f\u0647 \u0627\u0633\u062a \u0628\u0631\u0627\u06cc \u0647\u062f\u0627\u06cc\u062a \u06a9\u0627\u0631\u0628\u0631 \u0628\u0647 \u0635\u0641\u062d\u0627\u062a \u062f\u06cc\u06af\u0631 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u06a9\u0646\u06cc\u0645.<\/p>\n<pre><code class=\"hljs\"><span class=\"hljs-keyword\">import<\/span> { useNavigate } <span class=\"hljs-keyword\">from<\/span> <span class=\"hljs-string\">'react-router-dom'<\/span>;\n\n<span class=\"hljs-keyword\">const<\/span> Home = <span class=\"hljs-function\">() =&gt;<\/span> {\n    <span class=\"hljs-keyword\">const<\/span> navigate = useNavigate();\n    <span class=\"hljs-keyword\">return<\/span> (\n        {<span class=\"hljs-comment\">\/* ... *\/<\/span>}\n        &lt;button onClick={<span class=\"hljs-function\">() =&gt;<\/span> navigate(<span class=\"hljs-string\">'\/products'<\/span>)}&gt;\n        {<span class=\"hljs-comment\">\/* ... *\/<\/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> \u0628\u0631 \u062e\u0644\u0627\u0641 <code>useHistory()<\/code> hook\u060c \u0627\u06cc\u0646 \u0646\u06cc\u0627\u0632\u06cc \u0628\u0647 \u0641\u0631\u0627\u062e\u0648\u0627\u0646\u06cc \u0646\u062f\u0627\u0631\u062f <code>push<\/code> \u0631\u0648\u0634.  \u062a\u0646\u0647\u0627 \u06a9\u0627\u0631\u06cc \u06a9\u0647 \u0645\u0627 \u0628\u0627\u06cc\u062f \u0627\u0646\u062c\u0627\u0645 \u062f\u0647\u06cc\u0645 \u0627\u06cc\u0646 \u0627\u0633\u062a \u06a9\u0647 \u0645\u0633\u06cc\u0631 \u0631\u0627 \u0628\u0647 \u0639\u0646\u0648\u0627\u0646 \u06cc\u06a9 \u0627\u0633\u062a\u062f\u0644\u0627\u0644 \u0628\u0647 \u0622\u0646 \u0645\u0646\u062a\u0642\u0644 \u06a9\u0646\u06cc\u0645 <code>navigate<\/code> \u062a\u0627\u0628\u0639.<\/p>\n<\/p><\/div><\/div><\/div>\n<h2 id=\"conclusion\"><span class=\"ez-toc-section\" id=\"%d9%86%d8%aa%db%8c%d8%ac%d9%87\"><\/span>\u0646\u062a\u06cc\u062c\u0647<span class=\"ez-toc-section-end\"><\/span><\/h2>\n<p>\u062f\u0631 \u0627\u06cc\u0646 \u067e\u0633\u062a\u060c \u0645\u0627 \u0628\u0647 \u062a\u0639\u062f\u0627\u062f\u06cc \u0627\u0632 \u0631\u0627\u0647\u200c\u0647\u0627\u06cc \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631 \u0628\u0627 React Router\u060c \u0631\u0648\u0634 \u0639\u0645\u0644\u06a9\u0631\u062f \u0622\u0646 \u0648 \u0631\u0648\u0634 \u0645\u062f\u06cc\u0631\u06cc\u062a \u0622\u0646 \u062f\u0631 \u0646\u0633\u062e\u0647 \u0642\u062f\u06cc\u0645\u06cc\u200c\u062a\u0631 \u0648 \u0622\u062e\u0631\u06cc\u0646 \u0646\u0633\u062e\u0647 v6 \u0646\u06af\u0627\u0647 \u06a9\u0631\u062f\u06cc\u0645.<\/p>\n<\/div>\n<p><br \/>\n<br \/>\u0645\u0646\u062a\u0634\u0631 \u0634\u062f\u0647 \u062f\u0631 1403-01-11 01:04:05<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;15309&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;\u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627 \u062f\u0631 React Router \u0627\u06af\u0631 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 \u0627\u06cc \u0647\u0633\u062a\u06cc\u062f \u06a9\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u0647\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646\u060c \u0627\u062d\u062a\u0645\u0627\u0644\u0627\u064b \u0627\u0632 \u0627\u0647\u0645\u06cc\u062a \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0635\u062d\u06cc\u062d \u0645\u0633\u06cc\u0631\u06cc\u0627\u0628\u06cc \u0622\u06af\u0627\u0647 \u0647\u0633\u062a\u06cc\u062f.  \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0622\u0645\u0648\u0632\u0634\u200c\u0647\u0627\u06cc React Router \u0631\u0627 \u0645\u0631\u0648\u0631 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u062f\u060c \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0645\u062a\u0648\u062c\u0647 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0628\u0647 \u0646\u062f\u0631\u062a \u0628\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627 \u0627\u0634\u0627\u0631\u0647 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f \u0648 \u062f\u0631 \u0639\u0648\u0636 \u062a\u0645\u0631\u06a9\u0632 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. \u0631\u0648\u06cc \u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 \u06a9\u0627\u0645\u067e\u0648\u0646\u0646\u062a \u0644\u06cc\u0646\u06a9  \u0628\u0647...&quot;,&quot;width&quot;:&quot;0&quot;,&quot;_legend&quot;:&quot;{score}\\\/{best} ({count} \u0631\u0627\u06cc)&quot;,&quot;font_factor&quot;:&quot;1.25&quot;}'>\n            \n<div class=\"kksr-stars\">\n    \n<div class=\"kksr-stars-inactive\">\n            <div class=\"kksr-star\" data-star=\"1\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"2\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"3\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"4\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" data-star=\"5\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n    \n<div class=\"kksr-stars-active\" style=\"width: 0px;\">\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n            <div class=\"kksr-star\" style=\"padding-left: 5px\">\n            \n\n<div class=\"kksr-icon\" style=\"width: 30px; height: 30px;\"><\/div>\n        <\/div>\n    <\/div>\n<\/div>\n                \n\n<div class=\"kksr-legend\" style=\"font-size: 24px;\">\n            <span class=\"kksr-muted\">\u0627\u0645\u062a\u06cc\u0627\u0632 \u0634\u0645\u0627 \u0628\u0647 \u0627\u06cc\u0646 \u0645\u0637\u0644\u0628<\/span>\n    <\/div>\n    <\/div>\n","protected":false},"excerpt":{"rendered":"<p><span class=\"span-reading-time rt-reading-time\" style=\"display: block;\"><span class=\"rt-label rt-prefix\">\u0632\u0645\u0627\u0646 \u0644\u0627\u0632\u0645 \u0628\u0631\u0627\u06cc \u0645\u0637\u0627\u0644\u0639\u0647: <\/span> <span class=\"rt-time\"> 4<\/span> <span class=\"rt-label rt-postfix\">\u062f\u0642\u06cc\u0642\u0647<\/span><\/span>\u0645\u0639\u0631\u0641\u06cc \u0627\u06af\u0631 \u062a\u0648\u0633\u0639\u0647 \u062f\u0647\u0646\u062f\u0647 \u0627\u06cc \u0647\u0633\u062a\u06cc\u062f \u06a9\u0647 \u06a9\u0627\u0631 \u0645\u06cc \u06a9\u0646\u06cc\u062f \u0631\u0648\u06cc \u0647\u0631 \u0628\u0631\u0646\u0627\u0645\u0647 \u0648\u0628 \u0645\u062f\u0631\u0646\u060c \u0627\u062d\u062a\u0645\u0627\u0644\u0627\u064b \u0627\u0632 \u0627\u0647\u0645\u06cc\u062a \u0631\u0627\u0647 \u0627\u0646\u062f\u0627\u0632\u06cc \u0635\u062d\u06cc\u062d \u0645\u0633\u06cc\u0631\u06cc\u0627\u0628\u06cc \u0622\u06af\u0627\u0647 \u0647\u0633\u062a\u06cc\u062f. \u0647\u0646\u06af\u0627\u0645\u06cc \u06a9\u0647 \u0628\u0633\u06cc\u0627\u0631\u06cc \u0627\u0632 \u0622\u0645\u0648\u0632\u0634\u200c\u0647\u0627\u06cc React Router \u0631\u0627 \u0645\u0631\u0648\u0631 \u0645\u06cc\u200c\u06a9\u0646\u06cc\u062f\u060c \u0645\u0645\u06a9\u0646 \u0627\u0633\u062a \u0645\u062a\u0648\u062c\u0647 \u0634\u0648\u06cc\u062f \u06a9\u0647 \u0628\u0647 \u0646\u062f\u0631\u062a \u0628\u0647 \u062a\u063a\u06cc\u06cc\u0631 \u0645\u0633\u06cc\u0631\u0647\u0627 \u0627\u0634\u0627\u0631\u0647 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f \u0648 \u062f\u0631 \u0639\u0648\u0636 \u062a\u0645\u0631\u06a9\u0632 \u0645\u06cc\u200c\u06a9\u0646\u0646\u062f. \u0631\u0648\u06cc \u0631\u0648\u0634 \u0627\u0633\u062a\u0641\u0627\u062f\u0647 \u0627\u0632 [&hellip;]<\/p>\n","protected":false},"author":3,"featured_media":9056,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1772,620],"tags":[1827,1828,1100,1842,3642,3843,1252,1840,2341,3845,2830,1776,1811,1786,3837,2433,1967,1890,3842,2051,1909,1841,1974,1807,3190,3453,1881,1103,2750,2171,1803,1889,2123,2667,2450,2590,3850,1956,3293,1806,1795,2111,3847,3841,3447,1913,3840,3567,1810,1790,3849,3846,3848,1818,2300,3844,2829],"class_list":["post-15309","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-javascript","category-programming","tag-react","tag-1828","tag-javascript","tag-nodejs-vps","tag-router","tag-3843","tag--nodejs","tag-1840","tag-2341","tag-3845","tag-2830","tag-1776","tag-1811","tag-1786","tag-3837","tag-2433","tag----nodejs","tag-1890","tag-3842","tag-2051","tag-1909","tag-1841","tag-1974","tag-1807","tag-3190","tag-3453","tag-1881","tag-1103","tag-2750","tag-2171","tag-1803","tag-1889","tag-2123","tag-2667","tag-2450","tag-2590","tag-3850","tag-1956","tag-3293","tag-1806","tag-1795","tag-2111","tag-3847","tag-3841","tag-3447","tag-1913","tag-3840","tag-3567","tag-1810","tag-1790","tag-3849","tag-3846","tag-3848","tag-1818","tag-2300","tag-3844","tag-2829"],"acf":[],"_links":{"self":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15309","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=15309"}],"version-history":[{"count":0,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/posts\/15309\/revisions"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media\/9056"}],"wp:attachment":[{"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/media?parent=15309"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/categories?post=15309"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/rasanegaar.com\/blog\/wp-json\/wp\/v2\/tags?post=15309"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}