Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/yunyoungsik/portfolio-react

Yunyoungsik Portfolio Site
https://github.com/yunyoungsik/portfolio-react

ajax axios express framer-motion gsap momentjs mongodb mongoose path proxy-middleware react split-type

Last synced: about 2 months ago
JSON representation

Yunyoungsik Portfolio Site

Awesome Lists containing this project

README

        

# portfolio_react

React를 이용하여 만든 포트폴리오는 웹사이트입니다.

직접 제작한 웹사이트의 간단한 설명과 링크, 깃허브 링크를 제공하고 있습니다.


## client
npx create-react-app .
npm install react-router-dom
npm install gsap
npm i @studio-freight/lenis
npm install react-syntax-highlighter
npm install axios
npm install http-proxy-middleware --save
npm install moment
npm install split-type
npm i framer-motion

## server
npm init -y
npm install express --save
npm install nodemon --save
npm install path --save
npm install mongoose --save

##
- 메인
메인 페이지에서는 useEffect를 이용하여 smooth, splint, homeMouse 등 함수들을 호출합니다.

Lenis를 이용하여 부드러운 스크롤, GSAP를 이용하여 마우스 이펙트, 슬라이드, 화면전환 효과를 구현하였습니다.

Link 컴포넌트를 통해 페이지 내에는 다양한 컨텐츠들이 Link 컴포넌트를 통해 연결되어 있습니다.

상단에 위치한 메뉴 아이콘 클릭 시, Nav 컴포넌트를 토글하여 메뉴를 활성화하거나 비활성화합니다.

Nav는 Framer-motion을 사용하여 제작되었습니다.


- 서브
서브페이지에서는 코드 하이라이팅을 위해 SyntaxHighlighter를 사용하였으며, 이 라이브러리는 코드를 강조하여 보기 좋게 표시해줍니다.

그리고 GSAP를 활용하여 subIntro, subSlider 등의 함수들을 통해 애니메이션을 초기화하고 실행하고 있습니다.

부드러운 스크롤을 위해 Lenis를 사용하는 smooth 함수도 구현되어 있고, CommentArea는 페이지에 댓글 기능을 추가하기 위한 컴포넌트입니다.


- 어바웃
About 페이지는 개발자에 대한 정보를 제공하며 Lenis 및 GSAP와 같은 라이브러리를 활용하여 부드러운 스크롤, 인트로 및 아웃트로 등 애니메이션를 구현했습니다.

페이지에는 개발자의 간단한 소개, 서비스 및 기술 정보, 소셜 링크 및 이메일 등이 제공되며, Link 컴포넌트를 통해 다른 페이지로 연결되어 있습니다.


## 트러블슈팅01
[문제]
Home, sub 페이지에서 About페이지로 넘어가도 Scroll 효과가 남아있음

[해결]
해당 기능이 적용된 페이지에 서 ScrollTrigger과 gsap 애니메이션을 해제하고 넘어가도록 처리함
```js
return () => {
// ScrollTrigger 해제
ScrollTrigger.getAll().forEach(trigger => {
trigger.kill();
});
// GSAP 애니메이션 중지 또는 제거
animation.kill();
};
```
## 트러블슈팅02
[문제]
배포한 페이지에 접속하고 나서 첫 페이지까지는 잘 렌더링이 되었으나, 페이지를 이동 한 후 새로고침 시 page not found 404라는 창이 뜨는 문제가 발생했다.

[원인]
spa방식인 리액트는 하나의 페이지인 index.html만 렌더링 하게 되며, 리액트가 최초 접속할 때의 url 은 / 이다. 서버는 기본 URL 요청이 들어왔을 때 index.html만 보내는 규칙만 갖고 있기 때문에 화면을 넘기면서 라우팅된 각 url(/a, /b)에 맞는 자원이 존재하지 않아 발생하는 오류이다.
그래서 이를 해결하기 위해선 URL에 대한 리디렉션 및 다시 쓰기 규칙을 재구성해야 한다.

[해결]
1. 프로젝트의 public 폴더 안에 다음과 같이 _redirects라는 이름의 파일을 생성하고, 아래와 같이 코드를 입력해 저장해 주었다.
```js
/* /index.html 200
```
2. package.json과 README파일이 있는 프로젝트 루트 디렉토리에 netlify.toml라는 이름의 파일을 생성한다.
```js
[[redirects]]
from = "/*"
to = "/index.html"
status = 200
```
그 후 위와 같이 코드를 작성해 저장 후 push해 주어 404 문제를 해결할 수 있었다.

## 배포
fly.io을 통하여 배포를 진행하였습니다.
```
iwr https://fly.io/install.ps1 -useb | iex
flyctl auth login
flyctl launch
flyctl deploy
```
```
.dockerignore셋팅
server\config\dev.js
node_modules

client\node_modules
```
```
추가셋팅
flyctl scale count 1 --app yunyoungsik-portfolio
fly machine update 6e824525f25138 --vm-memory 256 --app yunyoungsik-portfolio
```

## 스택


Environment







Development








Communication