오늘은 SPA가 무엇인지 이해하고 Router에 대해 학습한 후 과제를 통해 주소에 따라 다른 페이지 뷰를 보여주는 방법을 적용해 본다.
학습 목표
- SPA(Single-Page Application) 개념을 이해하고 설명할 수 있음
- SPA의 장, 단점에 대해 이해하고 설명할 수 있음
- 와이어프레임을 보고 어느 부분을 컴포넌트로 구분할지 스스로 정할 수 있음

SPA는 하나의 페이지를 가지고 있지만 한 종류의 화면만 사용하지 않음. 따라서 화면에 따라 "주소"도 달라짐.
npx create-react-app@latest 폴더이름
cd 폴더이름
npm start //실행 결과가 잘 나오는지 확인하는 명령어
npm install react-router-dom@^6.3.0import {BrowserRouter, Routes, Route, Link} from "react-router-dom"
학습 목표
- npm 을 이용해 react-router-dom을 설치할 수 있음
- 컴포넌트 단위로 Client-side routing 을 할 수 있음
- react-router-dom 를 활용하여 Twittler SPA를 구현할 수 있음
1.과제 시작 전 fork 하고 터미널에서 git clone 명령어로 레포지토리를 클론 후
2.React Router를 이용하기 위해 react-router-dom을 설치
npm install react-router-dom@^6.3.0
React Twittler SPA의 파일구조는 아래와 같음. 파일구조 잘 봐두기!

오늘 과제는 어제하던 과제를 이어서 하는 거였는데, 왼쪽 사이드바에 있는 아이콘을 누르면 페이지가 이동하도록 만들었다.
//App.js
import React from 'react';
import './App.css';
import './global-style.css';
import {BrowserRouter, Routes, Route, Link } from "react-router-dom";
// TODO - react-router-dom을 설치 후, import 구문을 이용하여 BrowserRouter, Routes, Route 컴포넌트를 불러오세요.
import Sidebar from './Sidebar';
import Tweets from './Pages/Tweets';
import MyPage from './Pages/MyPage';
import About from './Pages/About';
// TODO - import문을 이용하여 MyPage, About 컴포넌트를 불러오세요.
const App = () => {
return (
<BrowserRouter>
<div>
{/* TODO - BrowserRouter 컴포넌트를 작성합니다. */}
<div className="App">
<main>
<Sidebar />
<section className="features">
{/* TODO - Routes와 Route 컴포넌트를 이용하여 경로(path)를 설정하고 Tweets, Mypage, About 컴포넌트를 연결합니다. */}
<Routes>
<Route path="/" element={<Tweets />} />
<Route path="/mypage" element={<MyPage />} />
<Route path="/about" element={<About />} />
</Routes>
</section>
</main>
</div>
</div>
</BrowserRouter>
);
};
//Sidebar.js
import React from 'react';
import {Link} from "react-router-dom"
// TODO - import문을 이용하여 react-router-dom 라이브러리의 Link 컴포넌트를 불러옵니다.
const Sidebar = () => {
return (
<section className="sidebar">
{/* TODO : About 메뉴 아이콘과 Mypage 메뉴 아이콘을 작성하고 Link 컴포넌트를 이용하여 경로(path)를 연결합니다. */}
<Link to="/">
<i className="far fa-comment-dots"></i> {/*Tweets 아이콘*/ }
</Link>
<Link to="/about">
<i className="far fa-question-circle"></i> {/*About 아이콘*/ }
</Link>
<Link to="/mypage">
<i className="far fa-user"></i> {/*MyPage 아이콘 */}
</Link>
</section>
);
};
export default Sidebar;
//Mypage.js
import React from "react";
import { dummyTweets } from "../static/dummyData";
import "./MyPage.css";
// ! 위 코드는 수정하지 않습니다.
import Footer from "../Footer";
// TODO - import문을 이용하여 Footer 컴포넌트를 불러옵니다.
const MyPage = () => {
// TODO - filter 메소드를 이용하여 username이 kimcoding인 요소만 있는 배열을 filteredTweet에 할당합니다.
const filteredTweets = dummyTweets.filter((el) => {
return el.username === 'kimcoding'
})
return (
<section className="myInfo">
<div className="myInfo__container">
<div className="myInfo__wrapper">
<div className="myInfo__profile">
<img src={filteredTweets[0].picture} />
</div>
<div className="myInfo__detail">
<p className="myInfo__detailName">
{filteredTweets[0].username} Profile
</p>
<p>28 팔로워 100 팔로잉</p>
</div>
</div>
</div>
<ul className="tweets__mypage">
{/* TODO : dummyTweets중 kimcoding 이 작성한 트윗 메세지만 있어야 합니다. */}
<li className="tweet" key={filteredTweets[0].id}>
<div className="tweet__profile">
<img/>
</div>
<div className="tweet__content">
<div className="tweet__userInfo">
<span className="tweet__username">{filteredTweets[0].username}</span>
<span className="tweet__createdAt">{filteredTweets[0].createdAt}</span>
</div>
<div className="tweet__message">{filteredTweets[0].content}</div>
</div>
</li>
</ul>
<Footer/>
</section>
);
};
export default MyPage;
배운점
import 로 불러와야 사용할 수 있다. (많이 쓰이니 기억하기..)import {BrowserRouter, Routes, Route, Link } from "react-router-dom";