생각정리
React 컴포넌트 이해하기: UI의 기본 단위
서론컴포넌트는 React로 UI를 구축하는 핵심 개념이다. 컴포넌트는 UI를 구성하는 블록으로, React 애플리케이션의 모든 요소는 컴포넌트로 나뉜다. 이번 글에서는 React 컴포넌트의 개념과 특징, 그리고 이를 효과적으로 사용하는 방법에 대해 살펴본다.컴포넌트란? 컴포넌트는 HTML, CSS, JavaScript 코드를 결합하여 재사용 가능한 UI 요소를 만드는 방법이다. 버튼의 rendering 로직과 markup을 한 컴포넌트 내에서 함께 관리함으로써, 이 둘이 항상 동기화 상태를 유지할 수 있게 한다. React에서는 JavaScript가 HTML을 관리하기에 rendering 로직과 markup이 같은 위치, 즉 컴포넌트 내에 존재한다. React 컴포넌트는 기본적으로 JavaScript 함..
React로 UI 구성: 단계별 접근 가이드
React로 사용자 인터페이스(UI)를 구축할 때는 먼저 UI를 구성 요소로 나누는 것부터 시작한다. 그런 다음 각 컴포넌트의 다양한 시각적 상태를 설명하고, 마지막으로 데이터를 통해 컴포넌트를 연결하게 된다. 이 글에선 React로 UI를 구축하는 단계별 접근 방법을 살펴보겠다.1단계: UI를 컴포넌트 계층으로 분해하기 UI를 React로 구축할 때 가장 먼저 해야 할 일은 UI를 컴포넌트 계층으로 분해하는 것이다. 이 과정에서 중요한 원칙은 단일 책임 원칙(Single Responsibility Principle)이다. 즉, 컴포넌트는 하나의 역할만 수행하도록 설계하는 것이 이상적이다. 만약 컴포넌트가 너무 커진다면, 이를 더 작은 컴포넌트들로 분해하는 것이 좋다. UI와 데이터 모델(json 형태를..
[JS] Promise와 Async/Await의 이해
서론 JavaScript에서 비동기 프로그래밍은 중요한 주제 중 하나이다. 비동기 작업은 코드의 흐름을 방해하지 않고, 동시에 여러 작업을 처리할 수 있게 해준다. 이러한 비동기 작업을 효율적으로 처리하기 위해 Promise와 Async/Await라는 두 가지 주요 도구가 있다. 이 글에서는 Promise가 무엇인지, 그리고 Async/Await와의 차이점이 무엇인지에 대해 좀 더 깊이 있게 다루고자 한다.PromiseJavaScript는 기본적으로 단일 스레드로 동작하기 때문에, 코드가 순차적으로 실행된다. 그러나 웹 애플리케이션에서는 네트워크 요청, 파일 입출력, 타이머 등 시간이 걸리는 작업을 처리해야 하는 경우가 많다. Promise는 비동기 작업이 완료되었을 때 결과를 사용할 수 있게 해주는 객..

네이버 부스트캠프 웹 풀스택 9기 챌린지 합격 후기
부스트캠프 챌린지 합격 후기 부스트캠프 챌린지 과정이 거의 끝나가는 지금, 챌린지에 붙기까지의 과정을 간단히 되돌아보며 후기를 남기고자 한다. 이 글은 부스트캠프 챌린지를 준비하는 이들에게 조금이나마 도움이 되길 바라는 마음으로 작성되었다.부스트캠프에 도전하려면 총 2개의 시험을 통과해야 한다. 그 후 챌린지 과정을 거치고, 마지막 3차 시험을 통해 최종 교육과정인 멤버십 과정에 들어갈 수 있는 사람을 선별한다. 올해부터 부스트캠프 챌린지 과정의 입과 시험이 바뀌었는데, 기존의 코딩 테스트만 있던 방식에서 CS 지식을 묻는 문제가 추가되었다.1차 코딩 테스트 1차 코딩 테스트는 매우 간단한 문제들 위주로 출제된다. 부스트캠프 측은 홈페이지에서 기본적인 CS 지식을 가진 사람을 원한다고 설명했기 때문에, ..
![[JS] Javascript에서 동기함수와 비동기함수의 차이](https://img1.daumcdn.net/thumb/R750x0/?scode=mtistory2&fname=https%3A%2F%2Fblog.kakaocdn.net%2Fdn%2FdmUX2I%2FbtsILFzlt3M%2FBEajfqyWqoeahiHrwC4YeK%2Fimg.png)
[JS] Javascript에서 동기함수와 비동기함수의 차이
Introduce 자바스크립트에서 동기와 비동기를 이해하는 것은 다른 프로그래밍 언어보다 중요하다. 왜냐하면 자바스크립트는 메일 스레드 하나만을 사용하는 단일 스레드 방식으로 설계되어 있으며 메인 스레드에서 뷰가 렌더링되고 사용자와의 상호작용이 많기 때문이다. 브라우저에서 메인 스레드가 blocking되면 웹페이지가 멈추는 프리징 현상이 발생하기에 사용자 경험에 문제가 생길 수 있다. 따라서 이 글에서는 동기와 비동기의 차이를 알아보고, 브라우저에서 이 두 방식이 어떻게 동작하는지 살펴보고자 한다. PreliminariesCall stackCall stack은 자바스크립트 엔진이 현재 실행 중인 함수와 그 함수들이 호출한 다른 함수들을 추적하는 자료 구조다. 이는 LIFO(Last In, First Ou..
[JS] Javascript에서의 FP
서론 함수형 프로그래밍은 패러다임중의 하나이다. 프로그램이 어떻게 동작해야 할지 일일히 명시하는 명령형 프로그램과 다르게 프로그램의 결과만을 입력하는 선언적 프로그램을 만드는 패러다임이다. 자바스크립트는 세가지 특징때문에 함수형 프로그래밍을 쓰기 편하다. 첫째로 클로저를 통해 외부 변수를 쉽게 참조할 수 있으며, 둘째로 1급 객체로서 함수를 값처럼 사용할 수 있어 코드의 유연성과 재사용성을 높인다. 마지막으로 모나드의 일종인 Promise를 통해 비동기 작업을 체계적으로 처리할 수 있다. 이러한 특징들은 JavaScript를 함수형 패러다임에 매우 적합한 언어로 만든다. 이를 통해 순수 함수로 부작용을 방지하고 불변성을 유지할 수 있어 코드의 안정성과 예측 가능성을 높일 수 있다.함수형 프로그래밍의 주..
[JS] Javascript에서의 모듈 시스템
서론JavaScript는 웹 개발에서 널리 사용되는 언어로, 시간이 지나면서 점점 더 복잡한 애플리케이션을 개발하기 위해 다양한 기능들이 추가되었다. 이 과정에서 모듈 시스템은 코드의 재사용성과 유지보수성을 높이는 중요한 역할을 하게 되었다. 모듈 시스템은 개발자가 큰 프로젝트를 작은 단위로 나누어 작업할 수 있도록 도와주며, 각각의 모듈은 독립적으로 개발되고 테스트될 수 있다. 이번 글에서는 JavaScript의 주요 모듈 시스템에 대해 자세히 살펴보겠다.JavaScript의 모듈 관리CommonJS CommonJS는 서버사이드 JavaScript 환경인 Node.js에서 주로 사용되는 모듈 시스템이다. CommonJS의 기본 아이디어는 각 파일을 독립적인 모듈로 간주하고, 이러한 모듈을 module...
[JS] Javascript에서의 OOP
서론 함수형 프로그래밍은 JavaScript 개발에서 중요한 패러다임이다. JavaScript는 함수형 프로그래밍의 여러 중요한 특징들을 지원하여 개발자들이 더 효율적이고 오류가 적은 코드를 작성할 수 있게 한다. 특히, 클로저를 통해 외부 변수를 쉽게 참조할 수 있으며, 1급 객체로서 함수를 값처럼 사용할 수 있어 코드의 유연성과 재사용성을 높인다. 또한, 모나드의 일종인 Promise를 통해 비동기 작업을 체계적으로 처리할 수 있다. 이러한 특징들은 JavaScript를 함수형 패러다임에 매우 적합한 언어로 만든다. 이를 통해 순수 함수로 부작용을 방지하고 불변성을 유지할 수 있어 코드의 안정성과 예측 가능성을 높일 수 있다. React에서는 이러한 함수형 패러다임을 권장하여 상속보다는 합성을 권장한..