Bun: 빠르고 혁신적인 JavaScript 런타임Bun이란?
·
Frontend/Development
Bun이란?Bun은 2023년 9월에 1.0 버전이 출시된 JavaScript 런타임으로, Node.js의 드롭인(drop-in) 대체를 목표로 합니다.Bun은 Zig언어로 개발되었으며, 구글 Chrome의 V8 엔진 대신 Apple의 JavaScriptCore엔진을 사용합니다. 이로 인해 속도와 실행 최적화에 강점을 가집니다.V8과 JavaScriptCore의 차이점특징V8(Chrome)JavaScriptcore(Safari)실행 속도 최적화고성능 JIT(Just In Time) 컴파일러, 빠른 실행빠른 초기 실행, 경량화메모리 사용비교적 높은 메모리 사용량최적화된 메모리 관리호환성Node.js와의 높은 호환성Apple 생태계 중심 최적화왜 0.xx 버전은 주목받지 못했을까?Bun이 처음 등장한 0.x..
npm이 설치하지 않은 패키지를 실행할 수 있는 이유
·
Frontend/Thoughts on Development
유령 의존성이란?개발 하다 보면, 어떤 패키지는 package.json에 명시적으로 추가한 적이 없는데도 프로젝트에 사용할 수 있는 경우가 있습니다. 또는 npm install을 했을 때 예상보다 더 많은 패키지가 설치되는 경우가 있습니다. 이런 현상을 유령 의존성이라고 부릅니다.📌 유령 의존성이 발생하는 주요 원인직접 설치하지 않은 패키지가, 하위 패키지를 통해 설치되면서 마치 직접 의존하는 것처럼 보이는 경우패키지 매니저에 따라 의존성 트리가 다르게 구성되는 경우=> npm은 90개의 하위 폴더, pnpm은 9개의 하위 폴더가 생김 📌 예제 재현mkdir npm-test && cd npm-testnpm init -ynpm install react react-dom typescript eslintm..
React 18, 19: 새롭게 나온 Hook 소개
·
Frontend/Development
React는 매 업데이트마다 개발자의 생산성과 사용자 경험을 개선하기 위해 새로운 기능을 도입해왔습니다. 특히 React 18과 19에서는 비동기 작업 관리와 UI 반응성을 향상시키는 여러 Hook이 추가되었습니다. 이번 글에서는 useId, useTransition, 그리고 useOptimistic과 같은 최신 Hook을 살펴보고, 이를 통해 어떻게 효율적인 비동기 처리가 가능한지 탐구해 보겠습니다.useIduseId는 React 18에서 고유한 ID 생성을 위해 도입된 Hook입니다. 서버와 클라이언트에서 동일한 ID를 생성하여 렌더링의 일관성을 보장하며, 클라이언트-서버 간 불일치를 방지할 수 있습니다.아래는 useId를 사용하여 고유 ID를 생성하고, 폼의 label과 input을 연결하는 예제입..
3개월 동안 글또 활동 회고
·
ETC
글또 참여 전: 꾸준한 글쓰기의 어려움"꾸준히 작성해야지."이 말은 제가 가장 자주 다짐했던 말 중 하나였습니다. 그러나 현실은 바빴던 업무와 일정, 그리고 "주말은 쉬어야 한다"는 핑계로 글쓰기를 미루기 일쑤였습니다. "이번 주는 시간이 없으니 다음 주에 써야지." 이렇게 미뤄둔 주제들은 점점 쌓여갔고, 결국 시기를 놓쳐 묻혀버리는 경우가 많았습니다. 특히 기술 블로그를 운영하는 것은 생각보다 어려운 일이었습니다. 단순히 개인적인 생각을 적는 것과 달리, 기술적인 글은 자료 조사, 코드 작성, 그리고 독자가 이해하기 쉽게 설명하는 노력이 필요했습니다. 이러한 과정을 반복하다 보면 쉽게 지치거나, '완벽하지 않다'는 불안감 때문에 시작조차 못한 적도 많았습니다. 그러던 중 글또라는 커뮤니티를 알게 되었습..
Atomic Design과 FSD, 그리고 내가 생각하는 아키텍처
·
Frontend/Thoughts on Development
들어가기최근 FSD(Feature-Sliced Design) 관련 글들을 많이 보게 되더라고요. 실제로 채용 과제에서 FSD 구조로 프로젝트를 작성해 오는 지원자도 봤었습니다. 한동안 Atomic Design 아키텍처가 많이 쓰였던 것 같은데, 요즘 FSD가 왜 이렇게 떠오르고 있는지 궁금해서 좀 찾아보았고, 그에 대해 제 생각도 정리해 봤습니다.일반적인 프로젝트 구조의 한계많은 프론트엔드 프로젝트에서 다음과 같은 구조를 흔히 볼 수 있습니다 (아닐 수도 있습니다... 😅):src/├── components/ # 공통 component├── utils/ # 공통 유틸 함수├── typings/ # 타입 정의├── hooks/ # 공통 커스텀 훅..
Module Federation을 위한 안전한 React 컴포넌트 로더 구현하기
·
Frontend/Module Federation
들어가며MF(Module Federation)은 Webpack 5의 핵심 기능으로, 여러 독립적인 애플리케이션 간에 코드와 리소스를 실시간으로 공유할 수 있게 해주는 기술입니다. 이 기술은 마이크로프론트엔드 아키텍처를 구현하는 데 매우 효과적인 도구이며, 대규모 프론트엔드 애플리케이션을 더 작고 관리하기 쉬운 단위로 분할할 수 있게 해줍니다.이에 대한 자세한 설명은 Micro Frontends와 MSA를 위한 Module Federation 글을 참고하시면 이해에 도움이 되실 것 같습니다.문제 상황마이크로프론트엔드 환경에서 MF를 사용하면서 다음과 같은 실제 문제들을 경험했습니다:로컬 개발 시 연결된 모든 서비스를 실행해야 하는 번거로움원격 서버 장애 발생 시 연관된 서비스까지 중단되는 문제컴포넌트 로딩..
끄적끄적 개발자
'분류 전체보기' 카테고리의 글 목록