react默认路由中的一个bug

作为一个初学框架的前端小白,自然免不了在使用框架做demo时出现各种问题。今天就介绍一个关于react-router中默认路由的一个bug。

<canvas width="300" height="300" ref="canvas"></canvas>

错误示例:
componentDidMount() {
setInterval(this.clock.bind(this), 1000);
}

clock() {
this.canvas = this.refs.canvas;
this.ctx = this.canvas.getContext(“2d”);
this.drawClock();
}
正确示例:

componentDidMount() {
this.canvas = this.refs.canvas;
this.ctx = this.canvas.getContext(“2d”);
setInterval(this.clock.bind(this), 1000);
}

clock() {
this.drawClock();
}

这两段代码的区别就是在于将获取canvas标签是否写在定时器内部。
当获取canvas在定时器内部时,每隔一秒总是会执行一次获取canvas标签。而这段代码所在的组件走的是默认路由,所以走其他路由时仍然会加载默认路由所对应的组件。而其他页面上没有ref为canvas的元素,所以在定时器不断地执行时,便获取不到该元素。便会出现报错。
而我们将获取canvas标签的语句写在定时器外时,由于在首页上会加载默认路由,canvas只需获取一次即可,便不会进入其他页面时再次获取canvas标签。
这也是我在初学react中遇到的一个比较重要的bug,想了一天才想明白其中原因。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
React 没有默认的路由,但你可以使用第三方库来处理路由。最常用的路由库是 React Router。你可以在项目安装 React Router,然后在你的应用程序定义路由和对应的组件。这样,当用户访问特定的 URL 时,React Router 将负责渲染相应的组件。 以下是一个使用 React Router 的基本示例: 首先,使用 npm 或者 yarn 安装 React Router: ``` npm install react-router-dom ``` 或者 ``` yarn add react-router-dom ``` 然后,在你的应用程序的顶层组件,引入 React Router 的相关组件: ```jsx import { BrowserRouter as Router, Route, Switch } from 'react-router-dom'; ``` 接下来,定义你的路由和对应的组件: ```jsx import Home from './components/Home'; import About from './components/About'; import NotFound from './components/NotFound'; const App = () => { return ( <Router> <Switch> <Route exact path="/" component={Home} /> <Route path="/about" component={About} /> <Route component={NotFound} /> </Switch> </Router> ); }; export default App; ``` 在上面的示例,`<Route exact path="/" component={Home} />` 表示当用户访问根路径时,渲染 `Home` 组件。`<Route path="/about" component={About} />` 表示当用户访问 "/about" 路径时,渲染 `About` 组件。`<Route component={NotFound} />` 是一个备用的路由,用于处理用户访问的不存在的路径。 这只是一个简单的示例,你可以根据你的应用程序需求来定义更复杂的路由。请参考 React Router 的官方文档以了解更多信息:https://reactrouter.com/web/guides/quick-start
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值