인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

도로롱님의 프로필 이미지
도로롱

작성한 질문수

프로젝트로 배우는 React.js

05 Fragment

react-router-dom 버전 업그레이드에 따른 문제

해결된 질문

작성

·

322

0

더이상 switch를 사용할 수 없다고 해서 routes, route로 바꿨더니

history.ts:480 Uncaught Error: [div] is not a <Route> component. All component children of <Routes> must be a <Route> or <React.Fragment>

 

위 오류가 나옵니다.

제 코드는 아래와 같습니다.

return (
    <Router>
     <div>
        <Link to="/">Home</Link>
        <Link to="/blogs">Blogs</Link>
     </div>
     <Routes>
      <Route path='/'><div>Home Page</div></Route>
      <Route path='/blogs' element={
        <div className='container'>
          <div className='mb-3'>
            <label className='form-label'>Title</label>
            <input className='form-control' value={title} onChange={(e) => setTitle(e.target.value)}/>
          </div>
          <div className='mb-3'>
            <label className='form-label'>Body</label>
            <textarea className='form-control' value={body} onChange={(e) => setBody(e.target.value)} rows='20'/>
          </div>
          <button className='btn btn-primary' onClick={onSubmit}>Post</button>
        </div>
      }>
      </Route>
     </Routes>
    </Router>
  )

답변 1

0

코지 코더님의 프로필 이미지
코지 코더
지식공유자

react-router-dom 버전 5를 사용해주세요 (npm i react-router-dom@5)

강의 내용에서 버전 5를 사용하고 있습니다.

끝부분에 82강에 버전 6으로 업그레이드 하는 영상 있으니 버전 5로 진행하시다가 버전 6으로 업그레이드 해보시면 좋을거 같습니다

 

도로롱님의 프로필 이미지
도로롱

작성한 질문수

질문하기