프린트 레이아웃과 함께

웹 디자인하기 🖨️🕸️🎨

CSS Paged Media 를 활용한 웹 이력서 프린트 디자인 사례 소개

FEConf 2024 Lighting Talk - 김무훈

iam@muhun.kim

프린트 레이아웃 디자인 동기

저는 이력서를 채용 지원 외에도 즉석에서 보여줘야 하는 다양한 상황을 경험했습니다.

이런 경우에 대비하여 디지털 환경에서 빠르게 열람할 수 있고, 멀티미디어와 함께 보여줄 수 있는 웹 이력서를 만들고자 했습니다.

read.cv - Amsterdam site template

마치 명함 교환처럼.. 간편한 이력 공유

실제로 인쇄하여 검토하지 않더라도 자주 사용되고 있는 규격입니다.

채용을 진행하는 입장에서 간편한 서류 선별을 위해 선호되기 때문입니다.

A4 size PDF = 구직 서류 규격

그러나,

이전에 받아본 웹 이력서가 느렸던 경험이나 정해지지 않은 형식에 대한 거부감도 있습니다.

해결책 - 웹으로 프린트 문서 조판하기

이 CSS 표준을 사용하면 웹 브라우저 인쇄 결과물의 레이아웃을 조정할 수 있습니다.

A4, B4, Letter 등 규격, 여백, 페이지 넘김, 방향 등 거의 모든 요소를 지원합니다.

CSS Paged Media W3C에서 논의 중인 인쇄 전용 CSS 표준입니다.

이 표준은 2004년부터 논의되고 있는 꽤 오래된 기능입니다.1

웹 페이지는 스크린 외에도 인쇄 매체의 조판에 활용할 수 있습니다.

앞서 언급한 문제는 텍스트 중심으로 내용을 구성하면 해결될 것이라고 생각했습니다.

이러한 콘텐츠를 보통 관련 커뮤니티에서 web-to-print(인쇄를 위해 만든 웹 콘텐츠)라고 불립니다.

약 3년 간 web-to-print 개인 이력서 변천사

프린트 결과물 시연

2019

2021

2023

스크린 화면 시연

https://frontend.moe/resume?print, 이 주소를 방문하셔서 인쇄를 바로 시도해보실 수 있습니다.

@page {
 size: A4 portrait;
 margin: 3cm 2cm;
}

* {
  break-inside: avoid;
}

↔️

번외 - 웹 서핑 시 PDF 아카이빙 팁

어때요? 콘텐츠 정보가 인쇄 규격에 더 잘 어울리게 배치되었나요?

 노션 기본 PDF 출력 결과물

오른쪽 코드 스니펫 추가 후 결과물

CSS Paged Media 스니펫 일부

IE 8(2009 부분 지원), 크롬(2011), 파이어폭스(2013년부터 부분 지원) 부터 지원: https://caniuse.com/?search=paged media

CSS 속성

환경

@page: margin
break-inside: avoid
@page size
@page: page-orientation

브라우저 지원 문제

*FireFox Nightly

앞서 설명한 바와 같이, 모든 브라우저에서 완전히 지원하지 않습니다.

간단한 개인 용도를 넘어 제대로 사용하려면 표준을 철저히 준수하는 컨버터를 사용해야 합니다.

찾아보면 WeasyPrint, PrinceXML, PDFreactor 등 여러 기업용 서비스가 있습니다.  이들은 외부 요청이 필요한 API 또는 헤드리스 브라우저 형태로 제공됩니다.

web-to-print 이력서

디자인 과정 소개

몇 가지 유용한 CSS Paged Media 기능을 소개하겠습니다.

핵심 요구사항

A4

스크린과 프린트 각각에 최적화된 레이아웃과 기능을 설계해야 합니다.

  • 프린트에서는 헤더, 푸터, 댓글 등 스크린 상에 보이는 UI를 포함해서는 안됩니다.
  • 프린트는 텍스트 중심으로 구성하고, 스크린에서는 이미지와 영상 등 멀티미디어를 추가로 표시합니다.

스크린

프린트

웹 디자인 작업

권장 가끔 사용 비권장
스크린 em, px, % ex pt, cm, mm, in, pc
프린트 em, cm, mm, in, pt, pc, % px, ex

인쇄 매체는 스크린과 달리 레이아웃의 너비가 고정되어 있으며, 픽셀이 아닌 cm, mm, pt와 같은 실제 물리적 단위가 표준으로 사용됩니다.

따라서 프린트 목업은 pt(포인트) 단위를 기준으로 디자인했습니다.

단일 진실의 원천, em = 공통 계층

*CSS media query 는 @media screen 만 있는 것이 아니라, @media print 도 있습니다.

동일한 콘텐츠에 대해 프린트와 스크린 스타일의 분기를 각각 정의하는 것은 번거롭고 유지보수가 어려워지는 작업이라 생각했습니다.

이 문제를 해결하기 위해 em 단위를 활용하여 프린트 및 스크린 디자인을 통합하는 방식을 채택하였습니다.

  • 프린트: 모든 요소의 크기를 rem 단위로 계산하여 일관된 디자인을 유지합니다. (1rem=11pt)
  • 스크린: 브라우저에서 대개 1rem=16px 인데, 별도의 추가 설정 없이도 반응형 디자인이 구현됩니다.
@media print {
 :root {
   font-size: 11pt;
 }
}

:root {
  // rem 기본 픽셀 크기는 브라우저 설정에 달렸는데, 대개 16px 입니다.
  font-size: 16px;
}

// 예시: 헤드라인 영역 및 하단 구분선
#header {
  h1 {
	font-size: 3.8rem;
  	margin-bottom: 2rem;
  }
  
  hr {
    max-width: 22.5rem;
    margin-top: 1rem;
    margin-bottom: 3rem;

    height: 0;
    border-top: solid 0.06rem var(--primary);
  }
}

em의 가변성이라는 특징 덕에 최적화된 비율을 유지할 수 있습니다.

세부 항목

프린트 레이아웃 우선 디자인하기

1. 인쇄 레이아웃 설정 - 규격 및 여백

@page {
 size: A4 portrait;
 margin: 3rem 4rem;
}

@media print {
 :root {
   font-size: 11pt;
 }
}

세부 항목

프린트 레이아웃 우선 디자인하기

1. 인쇄 레이아웃 설정 - 규격 및 여백

2. 웹 페이지 보이는 헤더, 푸터, 댓글 UI는 print media query 로 숨김 처리

@page {
 size: A4 portrait;
 margin: 3rem 4rem;
}

@media print {
 :root {
   font-size: 11pt;
 }

 .header,
 .footer,
 .comments {
   display: none;
 }
}

세부 항목

프린트 레이아웃 우선 디자인하기

1. 인쇄 레이아웃 설정 - 규격 및 여백

2. 웹 페이지 보이는 헤더, 푸터, 댓글 UI는 print media query 로 숨김 처리

3. 페이지 넘김 방지 설정하기

웹 문서를 프린트 시 중간에 이미지, 텍스트 등 내용이 다른 페이지에 이어서 나눠어지는 문제가 흔합니다.

avoid-page 속성 값 명시로 피할 수 있습니다.

@page {
 size: A4 portrait;
 margin: 3rem 4rem;
}

@media print {
 :root {
   font-size: 11pt;
 }
 
 .header,
 .footer,
 .comments {
   display: none;
 }
 
 .project {
  break-inside: avoid;
 }
}

페이지 넘김 방지 적용 전후 비교

적용 전

적용 이후

인쇄 결과물 전용 UI

인쇄물에서만 표시되는 요소를 설정할 수 있습니다.

  • 원본 웹 페이지 주소
  • QR 코드
.print {
  display: none;
}

@media print {
  .print {
    &:after {
      margin-left: 0.5rem;
      content: url(https://api.qrserver.com/v1/create-qr-code/?size=64x64&data=https://www.frontend.moe/resume);
    }
  }
}

스크린

프린트

작업 팁

브라우저 개발 도구에는 print media 에뮬레이션 기능이 있습니다.

이 기능은 웹 페이지의 콘텐츠를 프린트 미디어로 에뮬레이션합니다.

Chrome: More tools - Rendering - Emulate CSS media type

print media query와 CSS Paged Media는 별개의 웹 표준 기능입니다.

오른쪽 사진과 같은 Paged Media로 설정된 결과물의 페이지 마진과 페이지별 내용은 개발 도구로 확인할 수 없지만, 각 요소의 스타일을 시각적으로 확인하는 용도로 유용합니다.

프린트 미디어 에뮬레이션

Firefox: 스타일 편집기 - "페이지에 인쇄 미디어 시뮬레이션 전환" 버튼

프린트 미디어 에뮬레이션

Safari: 요소 인스펙터 - "프린트 미디어 스타일 강제 적용" 프린터 아이콘(🖨️) 버튼

요약

CSS Paged Media 는 웹 브라우저의 인쇄 레이아웃을 디자인하기 위한 기능입니다.
규격, 여백, 페이지 넘김, 방향 등 조판에 필요한 거의 모든 요소를 지원하고 있습니다.

  • 이 발표에서는 해당 기술의 응용을 인쇄 매체 저작으로만 한정하지 않고, 인쇄와 화면, 두 가지 환경을 같이 지원하는 통합적인 웹 디자인 방법을 소개했습니다.
  • 인쇄와 화면 간의 시각적 일관성을 rem 단위를 공통 디자인 시스템으로 활용하여 유지하고, media query 를 활용하여 각 매체에 최적 레이아웃을 제공했습니다.

  • 드래프트 웹 표준으로 모든 브라우저를 지원하는 하위 기능이 제한적이라, 이를 주의하셔야 합니다. 모든 기능을 제대로 활용하려면 전용 컨버터를 찾으셔야 합니다.

다음의 자료와 사례가 도움이 되었습니다.

아웃링크

프린트 레이아웃과 함께 웹 디자인하기

By Mu Hun

프린트 레이아웃과 함께 웹 디자인하기

FEConf 2024 라이트닝 토크에서 인쇄 전용 CSS 웹 기술을 활용해서 A4 규격 인쇄를 같이 지원하는 웹 디자인 방법을 소개했습니다. 슬라이드 내용으로 프린트 웹 디자인을 고민하게 된 동기, 작업 과정, 브라우저 지원 문제, 인쇄된 결과를 다루었습니다.

  • 137