我正在尝试将 react-router 与 react-three-fiber 一起使用。问题是<Switch>
组件在添加到 react-three-fiber<Canvas>
元素中时会丢失其上下文。为了解决这个问题,我可以将开关包裹<Router>
在画布内。手动输入 url 时,路由按预期工作。但是,` 元素现在似乎引用了另一个路由器,并且在单击时不起作用。
有没有办法让<Canvas>
参考内部和外部的元素成为同一个路由器?
https://codesandbox.io/s/reach-router-starter-v1-9qcjc
const App = ({ router }) => {
return (
<Router>
<div>
<ul>
<li>
<Link to="/">Home</Link>
</li>
<li>
<Link to="/about">About</Link>
</li>
<li>
<Link to="/dashboard">Dashboard</Link>
</li>
</ul>
<hr />
<Canvas>
<Plane color="black" position={[-5, 0, 0]} />
<Router>
<Switch>
<Route exact path="/">
<Home />
</Route>
<Route path="/about">
<About />
</Route>
<Route path="/dashboard">
<Dashboard />
</Route>
</Switch>
</Router>
</Canvas>
</div>
</Router>
);
};
const Home = () => <Plane color="red" position={[0, 0, 0]} />;
const About = () => <Plane color="green" position={[0, 0, 0]} />;
const Dashboard = () => <Plane color="blue" position={[0, 0, 0]} />;