IT 콘텐츠를 스크랩하고 관리해 보세요!
성장에 도움이 되는 IT 콘텐츠를 스크랩하고 관리해 보세요!
스크랩북 시작하기
다른 서비스
NEW
기획
디자인
개발
프로덕트
아웃소싱
프리랜싱
비즈니스
최근 검색어
전체 삭제
최근 검색어가 없습니다.

본문은 요즘IT와 번역 업체 Sprok DTS가 함께 만든 해외 번역 콘텐츠입니다. 이 글을 작성한 Vlad Batushkov는 아고다에서 엔지니어링 매니저로 일하고 있으며, Neo4j 커뮤니티에서 활발하게 활동하면서 여러 글을 올리고 있습니다. 이번 글은 개발자에게 가장 중요한 업무 중 코드 리뷰에 관한 문화와 커뮤니케이션 방법에 관해 설명하고 있습니다.

회원가입을 하면 원하는 문장을
저장 할 수 있어요!

다음

회원가입을 하면
성장에 도움이 되는 콘텐츠를
스크랩할 수 있어요!

확인

개발

코드 리뷰 문화

 

본문은 요즘IT와 번역 업체 Sprok DTS가 함께 만든 해외 번역 콘텐츠입니다. 이 글을 작성한 Vlad Batushkov는 아고다에서 엔지니어링 매니저로 일하고 있으며, Neo4j 커뮤니티에서 활발하게 활동하면서 여러 글을 올리고 있습니다. 이번 글은 개발자에게 가장 중요한 업무 중 코드 리뷰에 관한 문화와 커뮤니케이션 방법에 관해 설명하고 있습니다.

 

이 글에서는 코드 리뷰 문화, 커뮤니케이션 및 코드 리뷰어의 기술에 대해 간략히 다뤄 볼까 합니다. 하지만, 구체적 코드 리뷰 수행을 위한 단계별 지침을 제공하는 것은 아니라는 걸 밝힙니다.

 

안녕하세요, 제 이름은 블라드(Vlad)이며, 아고다(Agoda)에서 엔지니어링 매니저를 맡고 있습니다. 아고다에서 선임 소프트웨어 엔지니어로부터 기술 책임자까지 경력을 쌓는 동안, 저는 매년 1,100회 이상의 기고를 작성했습니다. 따라서, 저의 코드 리뷰 경험은 상당히 축적되었다고 할 수 있습니다.

 

코드 리뷰 작성
3년간 점진적으로 증가한 코드 리뷰 작성: 16% -> 24% -> 35%

 

코드 리뷰는 코드 작성자와 코드 리뷰어 간의 대화입니다. 그러나, 효과적인 대화는 평범한 코드 리뷰를 탁월한 학습 기회로 발전시킬 수 있습니다. 어떻게 가능한 지 한번 볼까요?

 

 

코드 리뷰 커뮤니케이션

코드 작성자가 코드 리뷰를 요청할 때 당사자는 기본적으로 승인을 기대합니다. 그러나 작성자가 작업을 수행하는 데 있어 진심으로 도움을 주고자 하는 리뷰어라면, ‘승인’인지 거부’인지 결정할 수 있어야 합니다. 이 간단한 이진법적 의사 결정 프로세스를 통해 양측의 건설적인 동작들에 대한 코드 리뷰 경험을 쌓게 되는 것입니다.

 

타협하지 않기

첫 번째 조언: 승인인지 거부인지 단호하게 결정하세요. 코멘트로 처리하는 코드 리뷰는 여러분이나 작성자, 어느 쪽에도 도움이 되지 않습니다. 코멘트는 여러분이 확신이 없거나 책임을 지지 않겠다는 신호에 불과할 수도 있습니다.

 

깃허브 코드 리뷰 옵션
GitHub 코드 리뷰 옵션

 

시간을 낭비하지 마세요. 수정할 사항이 없다면, 승인하면 됩니다. 물론 대부분은 코드 수정을 제안하게 되지만요. 여러분이 추천하는 모든 코드 수정 권장 사항이 필수적인 변경 사항은 아니라고 생각한다면, 역시 해당 코드를 승인하세요. 사실 그 작성자가 여러분의 모든 의견을 무시해도 된다는 생각이 든다면, 그때도 승인하세요. 그렇지 않은 경우라면 변경을 요청해야 합니다.

 

여러분은 리뷰어로서 거부(변경 요청) 권한이 있습니다. 변경이 필요한 항목이 있을 때마다 사용하세요. 어떤 변경이든 상관없습니다. 형식 변경이든, 복잡한 리팩터링[1]이든 무엇이든 요청해도 됩니다. 변경이 필요하다고 판단한다면, 해당 변경 사항을 요청하세요. 간단합니다.

 

의사소통하기

변경 요청의 목적은 코드베이스[2]를 개선하고 실수를 방지하며 지식을 공유하기 위한 것입니다. 코드 리뷰 거부로 인해 개발의 의욕이 떨어지거나 속도가 느려지면, 의사소통을 개선해야 합니다. 거부 자체에는 문제가 없지만, 서로 간 커뮤니케이션의 속도와 대화 품질에는 문제가 발생할 수 있으니까요.

 

거부 후 다음 코드 리뷰 라운드에 대해서는 신경 끄겠다는 생각은 좋지 않습니다. 여러분이 거부했다면, 작성자에게 언제 어느 때고 응답해 주어 최고의 경험이 되도록 해야 합니다. 작성자는 여러분의 모든 우려 사항이 처리되는 대로 즉시 당신의 승인을 받아야 합니다. 코드 리뷰어는 신속히 응답할 책임이 있습니다.

 

코드 한 줄만 확인한 후 그 나머지 부분은 전혀 확인하지 않고 오직 한 가지 변경만 요청하는 것도 옳지 않습니다. 반드시 모든 diff[3]를 확인하여 변경이 필요한 전체 사항들을 한 번에 요청하세요. 프로세스가 핑퐁 게임이 되지 않도록 말입니다.

 

창의적으로 활용하기

동료들과 함께 대형 프로젝트를 구축하고 있다면, 코드 리뷰 작업을 토대로 프로세스를 진행해 보세요. 다른 사람들에게 ‘서비스로 코드 리뷰’를 제공해 보세요. 봇이나 자동화 프로세스의 도움을 받아, 코드 검토 요청과 온콜 업무를 위한 전용 통신 채널을 사용해도 좋습니다. 코드 리뷰 응답 시간에 대한 합리적인 SLA[4]를 설정하는 것도 크게 추천할 만합니다. 코드 검토 업무를 제어/실행하고 데이터를 수집하며 시간 경과에 따라 결과를 개선하는 데 있어 탁월한 도움이 되니까요.

 

슬랙 코드 리뷰 자동화
슬랙(Slack) 채널 코드 리뷰 자동화

 

 

코드 리뷰어 스킬

이제 코드 리뷰어의 최고의 기술에 대해 이야기해 볼까요?

 

코드 리뷰의 결과는 전적으로 코드 리뷰어의 전문성과 개인적인 스킬에 달려 있습니다. 모든 풀 리퀘스트(Pull Request)[5]에 대해 좋은 코드 리뷰 메시지를 제공하는 것은 어려운 일이지만 그래도 매번 반복해서 시도해야 합니다. 성공의 열쇠는 우수한 코드베이스 지식과 기억력, 좋은 분위기에 있답니다. 그럼, 하나씩 차례로 살펴봅시다.

 

전문가 되기

엄두가 안 날지 모르지만, 코드베이스에서 일어나는 사항들에 대해 충분한 이해가 있어야 합니다. 즉, 프로그래밍 언어적 측면을 알고 프레임워크 플랫폼을 완벽하게 이해하며 프로젝트 아키텍처, 그리고 끝으로 비즈니스 영역까지 이해해야 합니다. 그것도 매우 깊이 있게. 마술처럼 되는 일은 없으니까요.

 

코드베이스 전문가가 되고자 한다면 매일 성실하게 일할 것.

 

멈춰서 분석하기

불행히도 모든 개발자가 현 코드베이스에 대해 충분히 알고 있는 것은 아닙니다. 세세한 부분까지 신경 쓰고 기억을 잘한다면 특별한 전문가가 되는 데 도움이 될 것입니다. 코드 리뷰 과정 중에는 코드 변경 사항만 보게 되는 한편, 전체 코드베이스는 리뷰어의 눈으로부터 가려져 있으므로 오직 기억에만 의존할 수밖에 없습니다. 따라서 머릿속에 프로젝트의 주요 부분을 담아 두고서, 누가 무엇을 하는지 기억하여, 여러 이니셔티브를 동기화할 수 있도록 합시다.

 

그렇다고 특정 프로젝트의 코드베이스를 외우느라 밤늦게까지 남아 있을 필요는 없습니다. 일상적으로 두뇌를 훈련하세요. 책을 많이 읽고, 체스와 같은 보드게임을 하고 분석하면서 기억력에 도전해 볼 수 있습니다. 새로운 언어(예를 들어, 일본어라든지)를 배우는 것도 기억력을 훈련하는 매우 유용한 방법입니다.

 

프로젝트 코드베이스
<출처: Unsplash>

 

존중하기

결코 부정적, 감정적, 혹은 파괴적인 어조로 코드 리뷰를 작성해서는 안 됩니다. 그렇게 하면 의사소통이 중단되고 갈등이 일어나며 타인의 감정을 상하게 할 수 있습니다(의욕 상실, 화와 분노 유발). 여러분 자신에 대한 평판에도 영향을 미칠 수 있으니, 정중하고 건설적이며 긍정적인 어조를 사용하는 것이 좋습니다.

 

변경을 제안할 때는 이유를 설명해야 합니다. 코드 조각, 예제 및 레퍼런스를 사용하세요. 코드 가이드라인 또는 코드 표준의 링크까지 공유해 주면 완벽하죠.

 

코드 설명하기
설명하기, 레퍼런스 달기, 제안하기.

 

 

보너스

코드 기여자의 좋은 습관은 자신의 코드가 검토받는 것입니다. 코드 리뷰는 코드 리뷰일 뿐, 여러분의 자존심을 내세울 필요가 없습니다. 코드 리뷰는 협력과 열린 마음가짐에 관한 것이니까요. 양측 모두의 관심사는 더 나은 결과와 지식 공유에 있다는 사실을 잊지 마세요.

 

 

요약

매일 코드 리뷰를 연습할 것, 코드베이스에 대해 학습할 것, 프로젝트에서 변경되는 사항들을 계속 주시할 것, 겸손하고 긍정적인 태도를 가질 것. 그렇게 하면, 곧 발견하게 될 겁니다. 갑자기 여러분 주변이 행복한 엔지니어들로 넘쳐나고 있다는 사실을 말이죠. 건투를 빕니다.


[1] 소프트웨어 공학에서 리팩터링(refactoring)은 ‘결과의 변경 없이 코드의 구조를 재조정함’을 뜻한다. 주로 가독성을 높이고 유지보수를 편하게 하는 것으로, 버그를 없애거나 새로운 기능을 추가하는 행위는 아니다.
[2] 코드베이스(codebase)는 특정 소프트웨어 시스템, 응용 소프트웨어, 소프트웨어 구성 요소를 빌드하기 위해 사용되는 소스 코드의 모임이다. 일반적으로 코드베이스에는 사람이 쓴 소스 코드 파일만 포함한다.
[3] diff는 두 개의 파일 간 차이에 대한 정보를 출력하는 파일 비교 유틸리티이다. 일반적으로 하나의 파일 버전과 동일한 파일의 다른 버전 간의 변경 사항을 보여주는 데 쓰인다. diff는 문서 파일의 줄 사이 변경 사항을 보여준다.
[4] SLA는 서비스 수준 협약서(Service Level Agreement)로, 서비스 제공에 있어서 공급자와 사용자 간의 서비스 측정지표와 목표 등에 대해 명시한 협약서이다. 일반적으로 여기에 포함될 수 있는 서비스 측정치들은 CPU의 가용시간, CPU 응답시간, 헬프 데스크 응답시간, 서비스 완료시간 등이다.
[5] 팀원들과 협업을 할 때 가장 중요한 기능으로, 병합을 하기 전 확인을 받는 절차이다.

 

<원문>

Code Review Culture
 

위 번역글의 원 저작권은 Vlad Batushkov에게 있으며, 요즘IT는 해당 글로 수익을 창출하지 않습니다.

좋아요

댓글

공유

공유

댓글 0

요즘IT의 번역글들

요즘 해외 개발자들은 어떻게 일할까요? 기획자나 디자이너는요? 그래서 준비했습니다. 읽어볼만한 해외 소식들을 번역해 전합니다. We are the world.

UX 디자이너에게 '제너럴리스트' 커리어가 함정인 이유

디자인

훌륭한 개발자의 5가지 특징

개발

구글AI '바드' 공개, SEO의 위기일까?

비즈니스

프로그래밍의 종말

개발

2023년 주목해야 하는 UI/UX 디자인 트렌드

디자인

나쁜 자바스크립트 작성 습관과 작별하기

개발

다음 11가지 언어들은 여전히 살아있나요?

개발

2023년 최고의 노코드 개발 도구

개발

디자이너를 위한 리액트 가이드

디자인

제품 관리의 제0법칙

기획

CTO는 어떤 일을 하나요?

개발

제품 디자인으로 5초 테스트하기

디자인

신입 개발자를 위한 완벽한 온보딩 가이드

개발

설문지 양식 UX: 더 나은 설문조사를 위한 언어

기획

영리한 개발자와 현명한 개발자의 차이점

개발

프리랜서 업무 로드맵 작성의 5단계

프리랜싱

모든 개발자가 시스템 디자인을 배워야 하는 이유

개발

주니어 개발자에서 미드레벨 개발자로 도약하기 위한 7단계

개발

최소 기능 제품 MVP, 이제 구시대적 발상인가요?

기획

스크럼이 개발자를 괴롭히는 9가지 이유

개발

북극성 지표(North Star Metric) 선택하기

비즈니스

피그마는 여러분을 나쁜 디자이너로 만들고 있습니다

디자인

인터랙션 디자인 vs 시각 디자인

디자인

좋은 디자인 포트폴리오를 만드는 팁

디자인

나에게 맞는 웹 기술 스택을 고르는 방법

개발

윈도우11은 실패작이다

프로덕트

“파이썬은 느리다”에 대한 반론

개발

파이썬 초보자가 저지르는 10가지 실수

개발

우리가 주목할 UI/UX 디자인 트렌드

디자인

2022년 프론트엔드 개발 동향

개발

데이터 분석가는 무슨 일을 할까요?

개발

최고의 오픈 소스 개발 도구 Top 8

개발

데이터 분석이란 무엇일까?

개발

Flutter로 UI를 구현하는 방법

개발

자바 언어의 장단점과 2022년 트렌드

개발

데브옵스(DevOps) vs 데브섹옵스(DevSecOps)

개발

엑셀을 사용한 아름다운 데이터 시각화

디자인

여러분을 더 나은 플러터 개발자로 만들어줄 7가지 프로젝트

개발

모든 디자이너가 숙지해야 할 피그마 팁과 노하우

디자인

디자인 원칙과 디자인 가치, 그리고 디자이너

디자인

디자인, 산출물 그 이상을 넘어

디자인

이 회사는 디자인에 투자하고 있는 회사일까요?

디자인

애자일은 정말 디자인을 배제하나요?

디자인

평판 관리가 프리랜서 경력에 미치는 영향

프리랜싱

리액트 네이티브 개발자들이 겪는 가장 빈번한 5가지 문제와 해결책

개발

“솔직히 우리가 하는 것은 스크럼이 아닙니다!”

기획

데이터 시각화가 인류를 위기에서 구한 세 가지 역사적 사건

디자인

NFT의 장밋빛 미래는 사실일까?

기획

피그마 토큰으로 디자인 시스템 만들기

디자인

디자이너+개발자 = 슈퍼팀 만들기

기획

1인 개발자로서 테크 스타트업을 운영하며

기획

웹 디자이너가 PX대신 REM을 사용해야 하는 이유

디자인

100개의 스타트업을 멘토링하며 깨달은 성공의 비밀

기획

중화권 앱 UI가 영미권 앱 UI와 다른 점 알아보기

프로덕트

내가 테크 리더로 일하면서 얻은 8가지 교훈

기획

모두가 즐길 수 있는 디자인 검토 회의 만들기

디자인

프로덕트 매니저에서 프로덕트 마스터로

기획

10배 이상 뛰어난 개발자가 되는 법

개발

제품 디자인 관점에서 바라보는 NFT 아바타 열풍

디자인

에어비앤비: 대규모 iOS 앱 개발 생산성을 위해 바꾼 것들

개발

스포티파이: 맞춤형 플레이리스트 개발 비하인드 스토리

개발

프리랜서가 일하게 될 15가지 유형의 프로젝트

프리랜싱

슬랙: 제품 원칙을 통해 다시 태어난 알림 기능

프로덕트

페이팔: 실시간 그래프 데이터베이스 분석을 통해 사기를 방지하는 방법

개발

트위터: 수십억 개의 이벤트를 실시간 처리하기

개발

슬랙: 4가지 애자일 가치와 방법

기획

스퀘어: 모바일 우선을 넘어 웹에서 누리는 모바일앱 경험

개발

스포티파이: 카피를 언어로 만드는 UX 라이팅

기획

마이크로소프트: 디자인의 미래를 위한 4가지 원칙

디자인

메타: AR/VR 경험까지 고려한 디자인 청사진

프로덕트

슬랙: 훌륭한 마케팅 카피를 위한 5가지 원칙

기획

2022년 UX/UI 디자인 트렌드

디자인

구글: 가변 폰트의 놀라운 활용법

디자인

에어비앤비: 위기 상황에서의 디자인 원칙 5가지

기획

어떻게 두 명의 인턴이 수백만 개의 코드들을 보호할 수 있었나

개발

Lattice로 마이크로 프론트엔드를 구축하는 법

개발

Cool Cats NFT를 구축하면서 배운 것

개발

웹 컴포넌트가 프론트엔드 프레임워크를 대신할까?

개발

당신이 NFT에 대해 알아야 할 모든 것

개발

우리에겐 이상하지만 개발자들에겐 일상인 일들

개발

Next.js 12에서 주목해야 할 5가지 변화

개발

스벨트 vs 리액트, 누가 더 뛰어날까?

개발

개발자를 위한 iOS 15의 새로운 기능

개발

내가 오픈소스를 싫어하는 이유

개발

프로덕트 매니지먼트 고객 여정 5단계

기획

클럽하우스의 인기는 모두 거품이었다?

프로덕트

데이터 기반 의사결정의 장점

기획

시각 디자인의 폐쇄성 법칙이란?

디자인

사용자 경험(UX) vs 서비스 디자인

기획

프로덕트 매니저는 하루 종일 무슨 일을 할까?

기획

제품 주도 성장은 어떻게 이루어지는가?

기획

UX를 망치지 않는 설득력 있는 배너 디자인

디자인

팝업(Pop-up)으로 불리는 것들에 대하여

디자인

드롭다운(Drop-down)으로 불리는 것들에 대하여

디자인

당신의 생각을 표현하는 새로운 이모지

디자인

가장 똑똑한 소프트웨어 엔지니어에게 배운 10가지 교훈

개발

성공적인 UX 프로젝트를 위한 가장 중요한 질문

디자인

2021년, UI 디자이너가 모바일 앱에서 흔히 저지르는 실수

디자인

IT 매니저가 되는 방법과 성공하기 위한 요소

기획

슬랙(Slack) 같은 앱을 만들려면 비용이 얼마나 들까?

개발

아웃소싱이 이토록 인기를 얻게 된 이유는?

아웃소싱

마케터가 UX 관련 역량을 키워야 하는 이유

기획

미니멀리즘 디자인의 핵심적인 요소들

디자인

새로운 소프트웨어 개발사가 필요하다는 7가지 신호

아웃소싱

2021년을 이끌어가는 프론트엔드 개발 트렌드 5가지

개발

PM을 성장시키는 학습 프레임워크

기획

UI 카피라이팅, 어떻게 써야 하나요?

기획

트렌드 예측: 경쟁에서 앞서는 방법

기획

제품 사고(product thinking)의 힘

기획

인하우스 vs 아웃소싱, 소프트웨어 개발 어떻게 하나요?

개발

그림을 못 그리는 사람도 쉽게 와이어프레임 그리는 방법

기획

스타트업 기업들에게 아웃소싱이 중요한 이유

아웃소싱

제품과 기능, 성공적으로 종료하는 방법 (下)

기획

제품과 기능, 성공적으로 종료하는 방법 (中)

기획

제품과 기능, 성공적으로 종료하는 방법 (上)

기획

UX 디자이너에게 반드시 필요한 12가지 스킬

디자인

패스워드 없는 세상이 오고 있다

개발

디자이너를 쉽게 잃는 방법 10가지

디자인

프론트엔드 코딩 작업에 영감을 줄 8가지 아이디어

개발

구글이 아웃소싱을 하는 이유: 아웃소싱 성공사례 5가지

아웃소싱

일 잘하는 PM이 되기 위한 로드맵 도구 5가지

기획

이제는 말할 수 있다! 아웃소싱에 대한 오해 11가지

아웃소싱

디자인 트렌드, 모던 미니멀 스타일의 UI 가이드

디자인

MVP 개발을 아웃소싱으로 해도 될까요?

아웃소싱

온보딩 효과를 높이는 '좋은' 귀차니즘 3가지

기획

게임처럼 즐겨라, 게임화 기법 TOP3

기획

시니어 소프트웨어 엔지니어는 어떻게 일할까?

개발

프로덕트 매니저가 글을 잘 써야 하는 이유

기획

2030년엔 사라질 수도 있는 프로그래밍 언어 5가지

개발

고객들이 언제나 옳은 것은 아니다

기획

유저 스토리는 무엇인가?

기획

고객 성공을 위한 14계명

기획

8px 그리드 시대가 끝나고, 4px 그리드의 시대가 열릴까?

디자인

모바일 앱은 더 이상 스타트업에게 좋은 아이디어가 아니다

비즈니스

과연 구글의 UX 강좌는 도움이 될까요?

디자인

프로덕트 매니저 여러분, ‘소비자의 요구사항 수집’을 그만두십시오

기획

고객 여정과 경험 지도의 차이점

기획

내가 AI 업계를 떠난 이유 5가지

개발

모달윈도우(팝업)를 디자인할 때 생각할 9가지 원칙

디자인

대기업 vs 중소기업, B2B SaaS 스타트업을 위한 시장은?

기획

내가 개발 인터뷰에서 면접자에게 감동한 이유

개발

HTTP의 새로운 메서드, 서치(SEARCH)에 대하여

개발

세상의 모든 프로덕트 디자이너를 위한 5가지 심리학 원칙

디자인

2021년 테스트 자동화 트렌드 리포트 (下)

개발

2021년 테스트 자동화 트렌드 리포트 (上)

개발

아마존과 스포티파이는 어떻게 사용자를 유지하고 측정할까?

기획

UX 디자이너라면 필수적으로 알아야 할 5가지 법칙

디자인

앵귤러 vs 리액트, 2021년의 승자는?

개발

2021년, SaaS 스타트업 시작을 위한 놀라운 아이디어 10가지

기획

디지털 제품 관리에서 B2B와 B2C 사이의 차이점은?

기획

빠르게 실행할 수 있는 ‘제품 요구사항 문서(PRD)’ 만들기

기획

더 나은 제품을 위한 프로덕트 메트릭스 가이드

기획

노 코드(No Code) 트렌드로 프로그래머들은 일자리를 빼앗길까?

개발

넷플릭스의 플랫폼: 코스모스(Cosmos)에 대하여

프로덕트

비즈니스와 애자일 조직은 어떻게 친해질 수 있을까요?

기획

효과적인 제품 전략 세우기: 다수의 전략적 트랙(MuST) 활용

기획

1년 만에 이메일 마케팅 효과를 극대화했던 방법

기획

솔루션 아키텍트를 위한 팁: 아키텍처 다이어그램의 5가지 유형

개발

새로운 맥 OS ‘빅서’에 대한 UX 디자이너의 생각

디자인

디자인 트렌드, 뉴모피즘의 정석

디자인

스스로 학습하는 UI/UX 디자이너가 되기 위한 2021년 로드맵, 3편

디자인

스스로 학습하는 UI/UX 디자이너가 되기 위한 2021년 로드맵, 2편

디자인

2021년 모바일 UX 트렌드 10가지

디자인

스스로 학습하는 UI/UX 디자이너가 되기 위한 2021년 로드맵, 1편

디자인

앱 설정 기능의 UX를 개선하는 효과적인 방법

디자인

다크모드 UI 디자인의 원칙

디자인

온라인 고객 경험을 개선하기 위한 5가지 방법

기획

신생 스타트업에서 일하는 프로덕트 매니저를 위한 현실적인 조언

기획

웹 개발자와 소프트웨어 개발자의 차이는 무엇인가요?

개발

랜딩 페이지 디자인을 개선하는 13가지 꿀팁

디자인

오프라인 비즈니스가 온라인에서 존재감을 가져야 하는 이유 5가지

기획

상향식 가격 책정 및 패키징 정책: 사용자 여정을 가이드로 활용하기

기획

B2B 제품의 UX, 그것은 숨겨진 영역인가요?

기획

상단 내비게이션 vs 사이드 내비게이션, 어느 것이 더 나을까?

디자인

자동완성 검색 기능 UX 설계를 위한 8가지 팁

디자인

프로덕트 매니저는 전문적인 IT 기술을 갖춰야 하나요?

기획

실리콘밸리 51개 기업들이 말하는 프로덕트 매니저의 역할 9가지

기획

아웃소싱에 대한 모든 것

아웃소싱

앱 디자인 가이드, 사람들이 즐겁게 사용할 수 있는 앱을 만드는 법

디자인

처음부터 완제품이 아니라 ‘MVP’를 만들어야 한다

기획

플러터 vs 리액트 네이티브 vs 네이티브, 성능이 더 우수한 것은?

개발

스타트업 프로덕트 매니저로 성장하는 법, 30-60-90일 플랜

기획

당신의 두뇌는 진보하고 있다: 성취감을 위한 3가지 전략

기획

디자이너들을 편하게 해주는 HTML/CSS 마법 10가지

디자인

코딩의 미래는 ‘노 코드(No Code)’이다

개발

내가 엔지니어링 매니저로 일하면서 저지른 실수들

개발

내가 롬 리서치(Roam Research)를 좋아하는 이유와 실제 사용법 (下)

기획

내가 롬 리서치(Roam Research)를 좋아하는 이유와 실제 사용법 (上)

기획

프로그레시브 웹 앱(PWA)이란 무엇이며, 왜 필요한가?

개발

PWA vs 네이티브 앱, 어떤 것을 선택해야 할까?

개발

UI 디자인에 여백을 활용하는 8가지 팁

디자인

마이크로소프트와 링크드인의 새로운 시도, 프리랜서 마켓에 도전장을 던지다

기획

토마스넷은 왜 가입자 수를 폭발적으로 늘려준 테스트 결과를 거부했을까?

기획

잘 팔리는 기업용 소프트웨어 디자인하기

디자인

파이어베이스(Firebase)란 무엇인가? 파이어베이스 심층 탐구 : 하편

개발

파이어베이스(Firebase)란 무엇인가? 파이어베이스 심층 탐구 : 중편

개발

파이어베이스(Firebase)란 무엇인가? 파이어베이스 심층 탐구 : 상편

개발

업워크(Upwork)가 조사한 요즘 가장 인기 좋은 개발 기술 15가지

개발

일자리 산업이 휴먼 클라우드(human cloud)에 적응하는 방법

기획

팬데믹 이후 세계에서의 디지털 가속화는 어떤 모습일까?

기획

같은 분야를 다룬 글들을 권해드려요.

요즘 인기있는 이야기들을 권해드려요.

좋아요

댓글

스크랩

공유

공유

지금 회원가입하고,
요즘IT가 PICK한 뉴스레터를 받아보세요!

회원가입하기
지금 회원가입하고,
요즘IT가 PICK한 뉴스레터를 받아보세요!
회원가입하고, 뉴스레터를 받아보세요!
회원가입하기