SVG란? SVG(Scalable Vector Graphics, SVG)는 2차원 벡터(Vector) 그래픽을 표현하기 위한 XML 기반의 파일 형식이다. SVG 파일의 장단점 장점 픽셀로 구성된 래스터(Raster) 파일과 달리, SVG는 벡터(Vector) 그래픽이기 때문에 크기를 조정해도 해상도를 유지한다. 비교적 많은 컬러 픽셀로 생성되는 래스터 이미지에 비해 용량이 작다. SVG 파일은 텍스트를 디자인이 아닌 텍스트 그대로 처리하기 때문에 스크린 리더가 SVG 이미지에 포함된 모든 단어를 스캔할 수 있다. 따라서 웹 페이지를 읽어야 할 때 유용하며 검색엔진은 SVG 이미지 텍스트를 읽고 색인을 달 수도 있다. 단점 SVG 파일은 로고, 일러스트레이션, 차트 등 웹 그래픽에 적합하며, 픽셀이 부족..
분류 전체보기
컴포넌트 만들기 전에 1. 외부 라이브러리의 컴포넌트는 Wrap 컴포넌트를 만든 다음에 사용 외부 라이브러리는 언제 사용을 중단할지 알 수 없어요. 관리 주체가 우리가 아니기 때문에 한계가 있기 때문이죠. 그러니 외부 라이브러리는 언제든 다른 라이브러리로 바꾸거나 자체 코드로 변경할 수 있도록 Wrap 컴포넌트를 만들어 사용해요. props 및 config를 프로젝트 전반에 동일하게 가져가려는 목적도 있어요. 컴포넌트 만들기 1. 파일과 디렉토리디렉터리 명은 케밥 표기법을 기본으로 사용하고, 리액트 컴포넌트 관련 디렉터리와 파일만 파스칼 표기법으로 사용 파일 내에서 컴포넌트 명이나 클래스의 이름을 표기할 때는 파스칼로 표기해요. 스토리북 내의 title은 파스칼케이스로 표기해요. 2. 함수 컴포넌트를 생..
Virtual DOM JavaScript 객체로 표현된 DOM이다. DOM 조작은 각 조작이 attachment → reflow → repaint 과정의 리렌더링을 일으킨다. 변화를 묶어서 DOM fragment에 적용한 다음, 한 번에 DOM에 반영하면 리렌더링을 줄일 수 있다. VirtualDOM은 변화가 일어나면 그 변화를 모아뒀다가 한 번에 적용시킨다. 즉, 리렌더링을 한 번만 일으킨다. 다시 말해, DOM fragment를 관리하는 과정을 직접 하지 않고, Virtual DOM이 자동화를 해주는 것이다. Virtual DOM의 처리 속도가 DOM 보다 절대적으로 빠르지는 않다. 다만 업데이트 처리가 간결해질 뿐이다. 렌더링 요인(트리 구성이 변화되지 않는 상황에서도)이 발생할 때마다 전체 트리의..
들어가며 어떻게 하면 협업을 잘 할 수 있을까? 를 고민할 때 빠지지 않는 것 중 하나가 어떻게 하면 커밋 메세지를 잘 쓸 수 있을까? 이죠. 커밋 메세지는 코드보다 더 유연하고 동일한 이슈도 사람마다 다르게 표현할 수 있는 부분이라, 커밋 메세지가 많이 누적될 수록 가독성은 점점 떨어질 수 밖에 없어요. 코드 리뷰에 도움이 되고 작업 히스토리를 잘 관리하기 위해서 사내 커밋 메세지 스타일을 정해본 적이 있는데, 그 내용을 공유합니다. 목표는 이거인데요. 1커밋 1깃모지를 사용하여, 커밋 작업 단위에 대한 생각을 재고합니다. 1커밋 1작업단위 원칙을 준수하여, 커밋의 목적을 명확하게 하고 의사소통의 효율성을 높입니다. 1커밋 1이슈 를 권장하여, 이슈 작업 범위의 일관성도 동시에 노려봅니다. 그러니까 이..