본문 바로가기

코드스테이츠 FE 45기

[React] 과제: React Twittler SPA

Bare minimum requirement

React Router 설치
react-router-dom을 npm으로 설치해야 합니다.

상세 컴포넌트 구현하기
App 루트 컴포넌트(App.js)import를 이용하여 Tweets, MyPage, About 컴포넌트를 불러옵니다.
Sidebar 메뉴 컴포넌트(Sidebar.js)Font Awesome을 활용하여 About 아이콘 <i className="far fa-question-circle"></i>을 넣어야 합니다.
Font Awesome을 활용하여 MyPage 아이콘 <i className="far fa-user"></i>을 넣어야 합니다.
Tweets 컴포넌트(Tweets.js)import를 이용하여 Footer 컴포넌트를 연결합니다.dummyTweets의 길이만큼 트윗이 보여야 합니다
MyPage 컴포넌트(MyPage.js)import를 이용하여 Footer 컴포넌트를 연결합니다.kimcoding이 작성한 트윗만 보여야 합니다.

React Route 적용하기
각 메뉴를 눌렀을 때, 주소에 맞게 페이지 뷰가 구현되어야 합니다.

컴포넌트별 기술 요구사항
App 루트 컴포넌트(App.js)
<BrowserRouter>, <Routes>, <Route> 로 React Router 문법에 맞게 컴포넌트가 있어야 합니다.
주소에 따른 페이지를 <Route> 컴포넌트를 이용하여 구분 지어 줍니다.
Tweets컴포넌트의 Route path는 "/"입니다.
About 컴포넌트의 Route path는 "/about"입니다.
MyPage 컴포넌트의 Route path는 "/mypage"입니다.
Sidebar 메뉴 컴포넌트(Sidebar.js)
<Link> 컴포넌트의 to 속성을 사용하여 SPA 내에서 페이지 전환에 따른 URL 업데이트를 진행해야 합니다.
Tweets 컴포넌트의 Route path는 "/"입니다.
About 컴포넌트의 Route path는 "/about"입니다.
MyPage 컴포넌트의 Route path는 "/mypage"입니다.

 

App.js

import React from "react";
import "./App.css";
import "./global-style.css";
// TODO - react-router-dom을 설치 후, import 구문을 이용하여 BrowserRouter, Routes, Route 컴포넌트를 불러오세요.
import { BrowserRouter, Routes, Route } from "react-router-dom";
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 (
    <div>
      <BrowserRouter>
        {/* TODO - BrowserRouter 컴포넌트를 작성합니다. */}
        <div className="App">
          <main>
            <Sidebar />
            <section className="features">
              <Routes>
                <Route path="/" element={<Tweets />}></Route>
                <Route path="/about" element={<About />}></Route>
                <Route path="/mypage" element={<MyPage />}></Route>
              </Routes>
              {/* TODO - Routes와 Route 컴포넌트를 이용하여 경로(path)를 설정하고 Tweets, Mypage, About 컴포넌트를 연결합니다. */}
              {/* <Tweets /> */}
            </section>
          </main>
        </div>
      </BrowserRouter>
    </div>
  );
};

// ! 아래 코드는 수정하지 않습니다.
export default App;

 

 

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((tweet) => {
    return tweet.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={"1"}>
          <div className="tweet__profile">
            <img src={filteredTweets[0].picture} />
          </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;

주의할 점은 Footer가 폴더 밖에 있기 때문에 경로를 ../Footer 로 할 것.

그 외엔 평탄하고 쉬운 과제였던 것 같다. 

Advanced 과제는 useNavigate 를 이용해 뒤로가기 기능을 구현하는 것인데 좀 더 도전정신 가득했으면 새 컴포넌트를 만들어보고자 하겠으나.. 거기까진 여유가 없어서 사이드바에 넣어버렸다. 

 

Sidebar.js

import React from "react";
// TODO - import문을 이용하여 react-router-dom 라이브러리의 Link 컴포넌트를 불러옵니다.
import { Link } from "react-router-dom";
import { useNavigate } from "react-router-dom";

const Sidebar = () => {
  const navigate = useNavigate();
  return (
    <section className="sidebar">
      {/* TODO : About 메뉴 아이콘과 Mypage 메뉴 아이콘을 작성하고 Link 컴포넌트를 이용하여 경로(path)를 연결합니다. */}
      <Link to="/">
        <i className="far fa-comment-dots"></i>
      </Link>
      <Link to="/about">
        <i className="far fa-question-circle"></i>
      </Link>
      <Link to="/mypage">
        <i className="far fa-user"></i>
      </Link>
      <button
        onClick={() => {
          navigate(+1);
        }}
      >
        <i class="fa-solid fa-arrow-right"></i>
      </button>
      <button
        onClick={() => {
          navigate(-1);
        }}
      >
        <i class="fa-solid fa-arrow-left"></i>
      </button>
    </section>
  );
};

export default Sidebar;

 

ETC

또 node가 삐걱거려 다시 한번 버전을 맞췄고 

그다음엔 테스트가 작동을 안했다.

 

에러메시지

비교적 명확한 에러미시지. @testing-library/dom 모듈을 찾을 수가 없다고 한다. 

어떻게 해결할까? 절친 chatGPT에게 물어본다.

"응 npm install 다시 하고 npm install @testing-library/dom 해봐~"

그러자 아래와 같이 package.json 파일에 dependency 부분에 @testing-library/dom 가 생겼다. 

 

왜 이런 에러가 생겼는지는 모르겠지만 어쨌든 뚝딱뚝딱 혼자(가 아니고 chatGPT랑 같이) 이것저것 해보는게 재밌다.

'코드스테이츠 FE 45기' 카테고리의 다른 글

[HTTP/Network] REST API  (0) 2023.05.26
[React] 과제: React Twittler State & Props  (0) 2023.05.23
[React] React SPA  (0) 2023.05.19
[React] 과제: React Twittler Intro  (1) 2023.05.19
[React] 리액트 기초  (0) 2023.05.18