首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >无法使用react路由器dom v6测试版传递状态,状态为空

无法使用react路由器dom v6测试版传递状态,状态为空
EN

Stack Overflow用户
提问于 2021-04-12 23:22:30
回答 1查看 692关注 0票数 1

App.js文件

代码语言:javascript
运行
复制
export default function App() {
    return (
        <div className="h-100">
            <Routes>
             <Link to={
                {
                    pathname: "/posts",
                    state: {test: 'test'}
                }
                }>Posts</Link>
                <Route path="/" element={<Home/>}/>
                <Route path="/login" element={<Login/>}/>
                <Route path="/posts" element={<Posts/>}/>
            </Routes>
        </div>
    )
}

预期要传递状态,当使用useLocation从另一页状态获取状态时,从一页到另一页的某些数据为null

index.js文件

代码语言:javascript
运行
复制
import {BrowserRouter as Router} from "react-router-dom";
import App from "./App";

ReactDOM.render(
    <React.StrictMode>
        <Router>
            <App/>
        </Router>
    </React.StrictMode>
    ,
    document.getElementById('root')
);

Posts.js文件

代码语言:javascript
运行
复制
const location=useLocation()
console.log(location);

输出

代码语言:javascript
运行
复制
Object { pathname: "/posts", search: "", hash: "", state: null, key: "hpuuzep5" }

package.json

代码语言:javascript
运行
复制
{
  "name": "chance",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "@testing-library/jest-dom": "^5.11.9",
    "@testing-library/react": "^11.2.5",
    "@testing-library/user-event": "^12.6.3",
    "axios": "^0.21.1",
    "bootstrap": "^5.0.0-beta3",
    "history": "^5.0.0",
    "ramda": "^0.27.1",
    "react": "^17.0.1",
    "react-dom": "^17.0.1",
    "react-router": "^5.2.0",
    "react-router-dom": "^5.2.0",
    "react-scripts": "4.0.2",
    "styled-components": "^5.2.3",
    "web-vitals": "^1.1.0"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject"
  },
  "eslintConfig": {
    "extends": [
      "react-app",
      "react-app/jest"
    ]
  },
  "browserslist": {
    "production": [
      ">0.2%",
      "not dead",
      "not op_mini all"
    ],
    "development": [
      "last 1 chrome version",
      "last 1 firefox version",
      "last 1 safari version"
    ]
  }
}

我不能从react- router -dom导入交换机,它显示交换机不是从react路由器dom导出的,我想我已经正确设置了我的路由,其中的错误是我无法将状态从一个路由传递到另一个路由。

EN

回答 1

Stack Overflow用户

发布于 2021-06-25 01:44:53

我可以通过这样做来获取state:

代码语言:javascript
运行
复制
<Link
  to={"/posts"}
  state={test: 'test'}>
    Posts
</Link>

我打开了类型声明,最终意识到状态是一个属性,而不是to对象https://github.com/ReactTraining/react-router/blob/dev/docs/api-reference.md#link的一部分

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67061088

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档