{"id":5941,"date":"2025-06-03T13:44:37","date_gmt":"2025-06-04T06:23:36","guid":{"rendered":"https:\/\/badgameshow.com\/steven\/?p=5941"},"modified":"2025-06-04T13:44:37","modified_gmt":"2025-06-04T06:23:36","slug":"%e5%a6%82%e4%bd%95%e5%9c%a8react%e4%b8%ad%e4%bd%bf%e7%94%a8reactrouter%e9%80%b2%e8%a1%8c%e8%b7%af%e7%94%b1%e7%ae%a1%e7%90%86%ef%bc%9f","status":"publish","type":"post","link":"https:\/\/badgameshow.com\/steven\/react-js\/%e5%a6%82%e4%bd%95%e5%9c%a8react%e4%b8%ad%e4%bd%bf%e7%94%a8reactrouter%e9%80%b2%e8%a1%8c%e8%b7%af%e7%94%b1%e7%ae%a1%e7%90%86%ef%bc%9f\/","title":{"rendered":"\u638c\u63e1 React Router\uff1a\u5728 React \u61c9\u7528\u4e2d\u8f15\u9b06\u9032\u884c\u8def\u7531\u7ba1\u7406\u7684\u7d42\u6975\u6307\u5357"},"content":{"rendered":"<p><meta name=\"keywords\" content=\"React, React Router, \u8def\u7531\u7ba1\u7406, \u524d\u7aef\u958b\u767c, JavaScript, React\u6559\u5b78\"><\/p>\n<h1>\u638c\u63e1 React Router\uff1a\u5728 React \u61c9\u7528\u4e2d\u8f15\u9b06\u9032\u884c\u8def\u7531\u7ba1\u7406\u7684\u7d42\u6975\u6307\u5357<\/h1>\n<p>React Router \u662f\u4e00\u500b\u529f\u80fd\u5f37\u5927\u7684 JavaScript \u5eab\uff0c\u5c08\u70ba\u5728 React \u61c9\u7528\u4e2d\u7ba1\u7406\u8def\u7531\u800c\u8a2d\u8a08\u3002\u5b83\u4e0d\u50c5\u7c21\u5316\u4e86\u8def\u7531\u7684\u69cb\u5efa\u904e\u7a0b\uff0c\u9084\u4f7f\u5f97\u524d\u7aef\u958b\u767c\u8005\u80fd\u5920\u5275\u5efa\u66f4\u5177\u52d5\u614b\u548c\u4e92\u52d5\u6027\u7684\u7528\u6236\u9ad4\u9a57\u3002\u672c\u6587\u5c07\u6df1\u5165\u4ecb\u7d39\u5982\u4f55\u5728 React \u4e2d\u6709\u6548\u5730\u4f7f\u7528 React Router \u9032\u884c\u8def\u7531\u7ba1\u7406\uff0c\u8b93\u60a8\u7684\u61c9\u7528\u7a0b\u5e8f\u66f4\u52a0\u6d41\u66a2\u548c\u9ad8\u6548\u3002<\/p>\n<h2>\u5982\u4f55\u5b89\u88dd React Router<\/h2>\n<p>\u5728\u958b\u59cb\u4e4b\u524d\uff0c\u60a8\u9700\u8981\u5c07 React Router \u5b89\u88dd\u5230\u60a8\u7684\u9805\u76ee\u4e2d\u3002\u60a8\u53ef\u4ee5\u4f7f\u7528 npm \u6216 yarn \u4f86\u9032\u884c\u5b89\u88dd\uff0c\u4ee5\u4e0b\u662f\u76f8\u61c9\u7684\u547d\u4ee4\uff1a<\/p>\n<pre class=\"brush: python\">\nnpm install react-router-dom\n\nyarn add react-router-dom\n<\/pre>\n<h2>\u57fa\u672c\u7528\u6cd5\uff1a\u4f7f\u7528 React Router<\/h2>\n<p>\u5b89\u88dd\u5b8c\u6210\u5f8c\uff0c\u60a8\u53ef\u4ee5\u958b\u59cb\u5728\u60a8\u7684\u61c9\u7528\u4e2d\u4f7f\u7528 React Router\u3002\u9996\u5148\uff0c\u60a8\u9700\u8981\u5f15\u5165\u76f8\u61c9\u7684\u7d44\u4ef6\uff1a<\/p>\n<pre class=\"brush: python\">\nimport { BrowserRouter as Router, Route, Link, Switch, Redirect } from 'react-router-dom';\n<\/pre>\n<p>\u63a5\u4e0b\u4f86\uff0c\u60a8\u9700\u8981\u5728\u61c9\u7528\u4e2d\u4f7f\u7528 `<Router>` \u7d44\u4ef6\u4f86\u5305\u88f9\u60a8\u7684\u8def\u7531\u914d\u7f6e\uff1a<\/p>\n<pre class=\"brush: python\">\n<Router>\n  <Switch>\n    <Route exact path=\"\/\" component={Home} \/>\n    <Route path=\"\/about\" component={About} \/>\n    <Route path=\"\/contact\" component={Contact} \/>\n    <Redirect from=\"\/old-path\" to=\"\/new-path\" \/>\n  <\/Switch>\n<\/Router>\n<\/pre>\n<p>\u4f7f\u7528 `<Switch>` \u7d44\u4ef6\uff0c\u60a8\u53ef\u4ee5\u78ba\u4fdd\u53ea\u6709\u7b2c\u4e00\u500b\u7b26\u5408\u8def\u5f91\u7684 `<Route>` \u6703\u88ab\u6e32\u67d3\uff0c\u9019\u6a23\u53ef\u4ee5\u907f\u514d\u591a\u500b\u8def\u7531\u7684\u91cd\u8907\u6e32\u67d3\u3002<\/p>\n<h2>\u5275\u5efa\u93c8\u63a5<\/h2>\n<p>\u5728\u60a8\u7684\u61c9\u7528\u4e2d\uff0c\u60a8\u53ef\u4ee5\u4f7f\u7528 `<Link>` \u7d44\u4ef6\u4f86\u5efa\u7acb\u5c0e\u822a\u93c8\u63a5\uff0c\u9019\u6a23\u7528\u6236\u53ef\u4ee5\u8f15\u9b06\u5730\u5728\u4e0d\u540c\u7684\u9801\u9762\u4e4b\u9593\u5207\u63db\uff1a<\/p>\n<pre class=\"brush: python\">\n<Link to=\"\/about\">About<\/Link>\n<Link to=\"\/contact\">Contact<\/Link>\n<\/pre>\n<h2>\u7e3d\u7d50\uff1aReact Router \u7684\u529b\u91cf<\/h2>\n<p>React Router \u662f\u4e00\u500b\u4e0d\u53ef\u6216\u7f3a\u7684\u5de5\u5177\uff0c\u80fd\u5920\u8b93\u60a8\u5728 React \u61c9\u7528\u7a0b\u5e8f\u4e2d\u8f15\u9b06\u7ba1\u7406\u8def\u7531\u3002\u900f\u904e\u672c\u6587\u7684\u4ecb\u7d39\uff0c\u60a8\u61c9\u8a72\u80fd\u5920\u719f\u6089 React Router \u7684\u5b89\u88dd\u3001\u8a2d\u7f6e\u53ca\u57fa\u672c\u7528\u6cd5\u3002\u900f\u904e\u4f7f\u7528 `<Router>`\u3001`<Link>`\u3001`<Route>` \u548c `<Switch>` \u7b49\u7d44\u4ef6\uff0c\u60a8\u53ef\u4ee5\u8f15\u9b06\u5275\u5efa\u5177\u5099\u591a\u9801\u9762\u5c0e\u822a\u7684\u61c9\u7528\u3002<\/p>\n<h2>\u9032\u4e00\u6b65\u5b78\u7fd2 React Router<\/h2>\n<p>\u5982\u679c\u60a8\u5e0c\u671b\u6df1\u5165\u4e86\u89e3 React Router \u7684\u66f4\u591a\u9ad8\u7d1a\u529f\u80fd\u548c\u6700\u4f73\u5be6\u8e10\uff0c\u8acb\u53c3\u8003\u5b98\u65b9\u6587\u6a94\uff1a[React Router Documentation](https:\/\/reactrouter.com\/web\/guides\/quick-start)\uff08\u65b0\u958b\u9801\u9762\uff09\u3002<\/p>\n<p>\u900f\u904e\u638c\u63e1 React Router\uff0c\u60a8\u5c07\u80fd\u5920\u63d0\u5347\u60a8\u7684\u524d\u7aef\u958b\u767c\u6280\u5de7\uff0c\u5275\u5efa\u51fa\u66f4\u5177\u4e92\u52d5\u6027\u548c\u7528\u6236\u53cb\u597d\u7684\u61c9\u7528\u7a0b\u5e8f\u3002<\/p>\n<p>&#8212;<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u6587\u7ae0\u6458\u8981\uff1a\u672c\u6587\u5c07\u8a73\u7d30\u4ecb\u7d39\u5982\u4f55\u5728React\u4e2d\u4f7f\u7528ReactRouter\u9032\u884c\u8def\u7531\u7ba1\u7406\uff0c\u5f9e\u5b89\u88dd\u5230\u8a2d\u7f6e\uff0c\u8b93\u4f60\u53ef\u4ee5\u5feb\u901f\u4e0a\u624bReactRouter\uff0c\u8f15\u9b06\u7ba1\u7406\u4f60\u7684React\u5c08\u6848\u3002<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"closed","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_jetpack_memberships_contains_paid_content":false,"footnotes":"","jetpack_publicize_message":"","jetpack_publicize_feature_enabled":true,"jetpack_social_post_already_shared":true,"jetpack_social_options":{"image_generator_settings":{"template":"highway","default_image_id":0,"font":"","enabled":false},"version":2}},"categories":[184,183],"tags":[182,181],"class_list":["post-5941","post","type-post","status-publish","format-standard","hentry","category-react","category-react-js","tag-react","tag-react-js"],"jetpack_publicize_connections":[],"jetpack_featured_media_url":"","jetpack-related-posts":[],"jetpack_shortlink":"https:\/\/wp.me\/pcFK27-1xP","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/badgameshow.com\/steven\/wp-json\/wp\/v2\/posts\/5941","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/badgameshow.com\/steven\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/badgameshow.com\/steven\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/badgameshow.com\/steven\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/badgameshow.com\/steven\/wp-json\/wp\/v2\/comments?post=5941"}],"version-history":[{"count":1,"href":"https:\/\/badgameshow.com\/steven\/wp-json\/wp\/v2\/posts\/5941\/revisions"}],"predecessor-version":[{"id":5942,"href":"https:\/\/badgameshow.com\/steven\/wp-json\/wp\/v2\/posts\/5941\/revisions\/5942"}],"wp:attachment":[{"href":"https:\/\/badgameshow.com\/steven\/wp-json\/wp\/v2\/media?parent=5941"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/badgameshow.com\/steven\/wp-json\/wp\/v2\/categories?post=5941"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/badgameshow.com\/steven\/wp-json\/wp\/v2\/tags?post=5941"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}