@media part-1 - by. UXKM

요약 설명

@media part1 에서는 @media의 속성 중
- 미디어 유형(Media types)
- 미디어 기능(Media features)
- 미디어 논리 연산자(Logical operators)
- 미디어 쿼리(Media Query) 문법
에 대한 내용을 다루고 있습니다.


@media을 사용하여 미디어 별로 style을 지정하는 것을 Media Query라 합니다. 디바이스를 지정하는 것뿐만 아니라 디바이스의 크기나 비율까지 구분할 수 있습니다.

출력 장치의 여러 특징 가운데 일부를 참조하여 CSS 코드를 분기 처리함으로써 하나의 HTML 소스가 여러가지 뷰를 갖도록 구현할 수 있는 명세입니다.
일반적으로 뷰포트 해상도에 따라 CSS 코드를 분기합니다.
대표적으로 사용하는 규칙은 반응형 레이아웃을 작업할 때 사용되며, 문서를 인쇄할 때 사용되기도 합니다.

미디어 쿼리(Media Query)는 CSS2부터 사용되었으며, 미디어 타입을 개선한 CSS3에서 본격적으로 쓰이기 시작한 웹 기법입니다.
미디어 쿼리는 반응형 웹의 핵심 기법이며, 화면의 폭이나 높이 등의 정보를 가지고 스타일을 개별적으로 줄 수 있습니다.

CSS2에서는 @media 규칙을 통해 서로 다른 매체 유형(media type)을 위한 맞춤식 스타일 시트(style sheet)를 지원합니다.
예를 들면, HTML 문서가 스크린에 표현될 때와 프린트할 때 서로 다른 스타일을 적용할 수 있습니다.

CSS3에서는 @media 규칙을 더욱 발전시켜 매체 유형(media type)과 하나 이상의 표현식(expression)으로 구성된 미디어 쿼리(media query)를 사용할 수 있습니다.
미디어 쿼리(media query)는 width, height, color 속성과 같은 미디어 관련 속성을 이용한 표현식을 통해 스타일이 적용되는 범위를 조절할 수 있습니다.
미디어 쿼리를 사용하면 콘텐츠(content)를 별도로 변경하지 않아도 웹 페이지에 접속하고 있는 기기에 알맞은 형태로 스타일이 조정됩니다.

3.9.1. 미디어 유형(Media types)

CSS3의 매체 유형은 이전 CSS2에서 정의된 것을 그대로 사용하고 있습니다.

사용하지 않는 미디어 유형에는
CSS2.1과 Media Queries 3 모듈에서 여러가지 추가 유형(tty, tv, projection, handheld, braille, embossed, aural)을 정의했으나 Media Queries 4에서 제거됐으므로 사용해선 안됩니다.
aural은 유사한 유형인 speech로 대체됐습니다.
미디어 유형은 선택사항입니다. 미디어 유형을 표시하지 않으면 미디어 쿼리는 기본값으로 모든 미디어 유형에 대한 것으로 해석됩니다.

all

기본값. 모든 미디어 장치(print | screen | speech)에 사용 됩니다.
미디어 타입이 생략되어 있어도 미디어 타입의 기본값은 all입니다.

print

프린터에 사용됩니다.

screen

컴퓨터나 태블릿, 스마트폰 등 스크린(screen)이 있는 매체에 사용됩니다.

speech

웹 페이지를 읽어주는 화면 낭독기(스크린 리더)에 사용됩니다.

3.9.2. 미디어 기능(Media features)

미디어 유형을 지정한 뒤에 규칙을 적용할 미디어 기능을 선정할 수 있습니다.
미디어 기능은 사용자 에이전트, 출력 장치 또는 환경 의 특정 특성을 설명 합니다.
미디어 기능 표현식은 해당 존재 또는 값을 테스트하며 전적으로 선택 사항입니다. 각 미디어 기능 표현식은 괄호로 묶어야합니다.
orientation 기능을 제외한 모든 기능 앞에는 min 또는 max 접두사를 사용할 수 있습니다.

@media 기능들을 적절히 활용하면 반응형 웹 사이트를 제작하는데 유용합니다.

뷰포트 크기에 따라 미디어 쿼리 적용

미디어 쿼리를 사용하면 반응형 환경을 만들 수 있습니다.
이 환경에서는 작은 화면과 큰 화면 및 그 사이의 모든 화면 크기에 특정 스타일이 적용됩니다.
미디어 쿼리 구문에서는 기기 특성에 따라 적용될 수 있는 규칙 생성을 허용합니다.

쿼리할 수 있는 항목에는 여러 가지가 있지만, 반응형 웹 디자인에 가장 자주 사용되는 항목은 min-width, max-width, min-heightmax-height입니다.

  1. min-width : 쿼리에 정의된 값보다 큰 브라우저 너비에 적용되는 규칙.
  2. max-width : 쿼리에 정의된 값보다 작은 브라우저 너비에 적용되는 규칙.
  3. min-height : 쿼리에 정의된 값보다 큰 브라우저 높이에 적용되는 규칙.
  4. max-height : 쿼리에 정의된 값보다 작은 브라우저 높이에 적용되는 규칙.
  5. orientation-portrait : 높이가 너비보다 크거나 같은 브라우저에 적용되는 규칙.
  6. orientation-landscape : 너비가 높이보다 큰 브라우저에 적용되는 규칙.

width

뷰포트의 너비, 높이.
뷰포트의 크기는 HTML body 콘텐츠를 표시하는 영역으로 실제 스크린의 크기와는 다릅니다.
반응형 웹 구현시 가장 일반적으로 사용하는 조건이 됩니다.

  1. Value : <length>
  2. Applies to : visual and tactile media types
  3. Accepts min/max prefixes : yes

device-width, device-height

스크린의 너비, 높이.
스크린은 출력 장치가 픽셀을 표시할 수 있는 모든 영역으로 일반적으로 HTML body 콘텐츠를 표시하는 뷰포트 보다 큽니다.

  1. Value : <length>
  2. Applies to : visual and tactile media types
  3. Accepts min/max prefixes : yes

aspect-ratio

화면 영역의 가로 세로 비율.
slash('/')를 사용하여 뷰포트의 너비와 높이에 대한 비율(양의 정수)을 [너비/높이] 순으로 작성해야 합니다.
min/max 접두사를 사용하면 너비 값의 최소/최대 비율을 정할 수 있습니다.

  1. Value : <ratio>
  2. Applies to : bitmat media types
  3. Accepts min/max prefixes : yes

devie-aspect-ratio

스크린의 너비와 높이에 대한 비율. '너비/높이' 순으로 조건을 작성합니다.
min/max 접두사를 사용하면 너비 값의 최소/최대 비율을 정할 수 있습니다.

  1. Value : <ratio>
  2. Applies to : bitmat media types
  3. Accepts min/max prefixes : yes

orientation

뷰포트의 너비와 높이 비율을 이용하여 가로 모드인지 세로 모드인지를 판단합니다.

  1. Value : portrait | landscape
  2. Applies to : bitmap media types
  3. Accepts min/max prefixes : no

color

매체 장치의 색상 구성요소 당 비트 수 (장치가 색깔 장치가 아니면 값은 0)
출력 장치의 색상에 대한 비트 수. 출력 장치가 컬러가 아닌 경우 0의 값에 대응합니다.

  1. Value : <integer>
  2. Applies to : visual media types
  3. Accepts min/max prefixes : yes

color-index

출력 장치가 색상 색인 테이블을 사용하는 경우 표현할 수 있는 색의 수.
출력 장치가 색상 색인 테이블을 사용하지 않으면 0의 값에 대응합니다. 현재 제대로 지원하는 브라우저가 없습니다.

  1. Value : <integer>
  2. Applies to : visual media types
  3. Accepts min/max prefixes : yes

monochrome

출력 장치가 흑백인 경우 픽셀당 비트 수.
출력 장치가 흑백이 아니라면 0의 값에 대응합니다.

  1. Value : <integer>
  2. Applies to : visual media types
  3. Accepts min/max prefixes : yes

resolution

출력 장치의 해상력에 대응합니다. min/max 접두사는 사각형 아닌 픽셀(인쇄 장치)에도 대응하지만 접두사 없는 resolution 조건은 사각형 픽셀에만 대응합니다. 조건의 값으로 dpi(dots per inch)와 dpcm(dots per cintimeter) 단위를 사용할 수 있습니다.

  1. Value : <resolution>
  2. Applies to : bitmap media types
  3. Accepts min/max prefixes : yes

3.9.3. 미디어 논리 연산자(Logical operators)

not, and, only와 같은 논리 연산자를 사용해 조합하여 복잡한 쿼리를 만들 수 있습니다.
여러 미디어 쿼리를 쉼표(,)로 구분해서 하나의 규칙으로 만들 수도 있습니다.

and 연산자 - 논리곱 연산자

여러 미디어 특징들을 하나로 결합합니다.
새로운 미디어 특징들을 추가할 때마다 and 연산자를 사용합니다.

위 한줄 예제는 [모든 유형의 장치, 최소 너비 700px 이상, 세로 모드]의 조건에 적용되는 예제입니다.

콤마(,) 또는 or 연산자 - 논리합 연산자

쉼표는 각각 개별 미디어 쿼리로 인식합니다.
쉼표는 여러 미디어 쿼리를 단일 규칙으로 결합하는 데 사용됩니다.
쉼표로 구분 된 목록의 각 쿼리는 다른 쿼리와 별도로 처리됩니다.
따라서 목록의 쿼리 중 하나라도 true이면 전체 미디어 문이 true를 반환합니다. 즉, 목록은 논리 or연산자 처럼 동작합니다.

위 한줄 예제는 [모든 유형의 장치, 최소 너비 700px 이상 or 프린트 장치 가로 방향]의 조건에 적용되는 예제입니다.

not 연산자 - 부정 논리 연산자

not 연산자는 쿼리가 그렇지 않은 경우는 false를 반환하는 경우는 true 반환, 미디어 쿼리를 부정하는 데 사용됩니다.
쉼표로 구분 된 쿼리 목록에 있으면 해당 쿼리가 적용되는 특정 쿼리만 무효화됩니다.
not 연산자를 사용하는 경우 매체 유형도 지정 해야합니다.

위 예제는 모든 색상 장치에서 이 스타일을 적용하지 않겠다는 조건입니다.

위 한줄 예제는 모든 스크린 색상 장치에서 적용하지 않거나, 프린트 색상 장치에서 적용되는 조건입니다.
쉼표로 분리하여 사용할 때, 미디어 구문은 개별 미디어 쿼리로 인식하므로 not은 쉼표 이후에 영향을 미치지 않습니다.

only 연산자

only 연산자는 전체 쿼리와 일치하는 경우에만 스타일을 적용하는 데 사용합니다.
미디어 쿼리를 지원하지 않는 브라우저(정확히는 legacy user agents)가 주어진 스타일을 적용하는 것을 방지합니다.
not이나 only를 사용하려면 미디어 유형을 규정해야 합니다.
미디어 쿼리는 대소문자 구별하지 않습니다.

3.9.4. 미디어 쿼리(Media Query) 문법

만약 웹 페이지에 접속하고 있는 기기의 매체 유형과 명시된 매체 유형이 일치하고, 모든 표현식이 참(true)이면, 미디어 쿼리는 참(true)을 반환합니다.
이렇게 미디어 쿼리의 반환값이 참이면, 해당 블록 안에 명시된 CSS 스타일 코드가 실행됩니다.
여기에 and, only, not 등과 같은 키워드를 사용하여 더욱 복잡한 조건을 명시할 수도 있습니다.

CSS 코드 내부에서 분기하는 방법

CSS 코드 내부에서 사용하는 미디어 쿼리의 기본적인 문법 예는 다음과 같습니다. 일반적으로 권장하고 널리 쓰이는 방식입니다.

  1. @media

    미디어 쿼리가 시작됨을 선언합니다. @media, only, all, and, (조건문) 사이에 포함되어 있는 공백은 필수적입니다.

  2. only

    only 키워드는 미디어 쿼리를 지원하는 사용자 에이전트만 미디어 쿼리 구문을 해석하라는 명령이며 생략 가능합니다.

    생략했을 때 기본 값은 only로 처리 됩니다. 생략해도 무방하므로 이 키워드는 일반적으로 작성하지 않습니다.

    이 자리에는 not 키워드를 사용할 수 있는데 뒤에 오는 모든 조건을 부정하는 연산을 합니다.

  3. all

    all 키워드는 미디어 쿼리를 해석해야 할 대상 미디어를 선언한 것입니다.

    all 이면 모든 미디어가 이 구문을 해석해야 합니다.

    all 키워드 대신 screen 또는 print와 같은 특정 미디어를 구체적으로 언급할 수도 있습니다.

    all 키워드는 생략 가능하고 생략했을 때 기본 값은 all 으로 처리됩니다.

    all, screen, print를 가장 많이 씁니다.

  4. and

    and 키워드는 논리적으로 'AND' 연산을 수행하여 앞과 뒤의 조건을 모두 만족해야 한다는 것을 의미합니다.

    조건이 유일하거나 또는 only, all과 같은 선행 키워드가 생략되면 and 키워드는 사용하지 말아야 합니다.

    and 대신 콤마 , 기호를 사용하면 'OR' 연산을 수행합니다.

    'OR' 연산은 나열된 조건 중에서 하나만 참이어도 {실행문}을 해석합니다.

  5. (조건문)

    브라우저는 조건문이 참일때{실행문}을 처리하고 거짓일 때 무시합니다.

    조건문은 두 가지 이상 등장할 수 있습니다.

    둘 이상의 조건문은 and 키워드 또는 콤마(,) 기호로 연결해야 합니다.

  6. {실행문}

    일반적인 CSS 코드를 이 괄호 안에 작성합니다.

    브라우저는 (조건문)이 참일때 실행문 안쪽에 있는 CSS 코드를 해석합니다.

CSS 코드 외부에서 분기하는 방법

조건문에 따라 별도의 외부 CSS 파일을 참조하여 분기하는 방법이며, 이 방식은 성능 최적화 측면에서 권장하지 않습니다.