본문 바로가기

NextJs6

Nextjs 기본 개발 팁 - dotenv lib 요즘은 다양한 플랫폼의 정보를 사용하게 되면서 인허가 받은 정보로 데이터를 가져오거나 Oauth 연동을 하는 경우가 많습니다. 이때, 이런 인가 코드를 코드 내에 하드 코딩하게 된다면 악의적인 용도로 사용되거나 예기치 못한 보안의 위협이 될 수 있습니다. 아래처럼 쉽게 endpoint 정보가 노출될 수 있습니다. 이런 보안 취약점을 보완하기 위해서 민감한 정보는 루트 경로에 .env 파일을 생성하여 작성하셔야 합니다. 1) 먼저, 프로젝트 내에 라이브러리 설치 합니다. sudo npm install dotenv 2) 프로젝트 설치 후 루트 경로에 .env 파일을 생성합니다. Next.js에서는 자동으로 개발과 운영 환경설정 파일을 구분하는데 구분하여 사용하고 싶으면 .env.development 파일과.. 2024. 3. 6.
Next.js 공통 스타일 정의는 반드시 globals.css globals.css를 사용하지 않고 우후죽순으로 스타일을 정의하다보면 변경 요건이 발생했을 때, 아래와 같이 유지보수에 어려움을 겪게 됩니다 ㅠㅠ 저도 최근에 바쁜 일정에 기획이 계속 바뀌다보니 우후죽순으로 스타일을 동적으로 정의하고 있었습니다. 그런데 기획자가 갑작스럽게 그러더라구요. "웹에서 앱을 사용 하듯이 사용자 화면 가운데 정렬되도록, 최대 가로크기는 max-width: 390px로 변경해주세요." 아래와 같이 디자인 요건에서 크기 정의가 필요한 것들만 430px로 정의해둔 상태였습니다. 요즘은 툴을 통해서 간편하게 수정이 가능하긴하지만 아래와 같이 globals.css를 사용했다면 한 줄만 수정하고 끝났을텐데 말이죠... 여러분 공통된 스타일은 반드시 globals.css에 정의합시다. 2024. 3. 3.
Recoil을 이용한 전역 상태관리 Recoil은 React 상태 관리 라이브러리 중 하나 입니다. recoil을 이용하면 전역으로 상태(특정 시간에서의 조건이나 정보) 관리할 수 있어 로그인 후 사용자 정보나 여러 컴포넌트에 최신으로 제공되어야하는 공통 정보를 유지하는데 이용이 가능합니다. react의 렌더링 특성을 잘 활용하여 효율적인 리렌더링을 제공해주므로 아래 몇 가지에 대한 정보만 파악해도 쉽게 사용 가능합니다. Atom: 앱의 상태를 정의하는 단위 Selector: 파생된 상태를 만들어내는 함수, 다른 Atom이나 Selector로부터 값을 받아 계산 Recoil Hook 종류 useRecoilValue: Atom 값 읽음 (상태 업데이트 트리거 하지 않음) useSetRecoilState: Atom 값을 업데이트 하는 sett.. 2024. 2. 25.
라이브러리와 프레임워크 차이 실제로 프로젝트를 하다보면 프레임워크와 라이브러리, 솔루션 등을 구분하지 못하는 분들이 종종 계시는데요. 비용을 지불하고 도입하면 솔루션으로 생각하시는 분들이 계시더라구요. 구분 방법은 아주 간단합니다. 크게는 프로그램의 흐름을 제어할 수 있는 권한이 나에게 있고 전체적인 개발 흐름에 제약을 주지않으면 라이브러리 프로그램의 흐름 제어 권한이 나에게 없고 전체적인 개발을 위해서 따라야할 제약이 존재한다면 프레임워크입니다. 예로 들면, React는 사용자 인터페이스를 만들기 위한 Javascript 라이브러리 Nextjs는 Node.js 위에 빌드된 오픈 소스 웹 개발 프레임워크 2024. 2. 25.