일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
Tags
- HTML
- CSS
- 웹
- es6
- 이슈
- 파이썬
- 프론트엔드
- 블록체인
- TypeScript
- 가상화
- 백준
- k8s
- 알고리즘
- 솔리디티
- BFS
- 컴퓨터공학
- react
- AWS
- JavaScript
- next.js
- node.js
- 백엔드
- 리액트
- 클라우드
- 타입스크립트
- 쿠버네티스
- 자바스크립트
- 이더리움
- docker
- kubernetes
Archives
- Today
- Total
즐겁게, 코드
머터리얼 UI에서 미디어쿼리 사용하기 본문
머터리얼 UI(Material UI) 기반 컴포넌트를 꾸밀 때는 makeStyles
라는 커스텀 훅과 객체를 사용해 CSS를 꾸미게 된다.
예를 들어 클래스명이 'card' 인 요소를 꾸미는 방법은 이런 식이다.
import React from "react";
import { Card, makeStyles} from "@material-ui/core";
const useStyles = makeStyles((theme) => ({
card: {
width: "80%",
height: "20%"
},
}))
const CardContainer = () => {
const classes = useStyles();
<Card className = {classes.card}></Card>
}
자바스크립트에서 객체를 사용하는 문법을 아는 사람이라면 뭔가 이상한 점이 하나 보일 것이다.
"그럼 스타일 객체 내에서 @media(max-width: 600px)
같은 미디어쿼리는 어떻게 사용하나요?"
안타깝지만 질문의 답은 "사용할 수 없습니다." 이다.
미디어쿼리를 사용하기 위해서는 별도의 CSS 파일을 구성해야 하는데, 이러면 클래스명이 겹쳐 원하지 않는 부분에도 미디어쿼리가 적용될 수 있게 되어 약간 위험한 코드가 탄생하게 된다.
머터리얼 UI는 이러한 점을 방지하고 사용자의 편의를 위해 반응형 디자인을 위한 useMediaQuery
라는 훅을 제공한다.
[useMediaQuery 훅 사용법]
import { useMediaQuery } from "@material-ui/core";
// 인자로 주어진 미디어쿼리 조건에 따라 true와 false를 리턴한다.
const isMobile = useMediaQuery("(max-width: 600px)");
useMediaQuery
를 사용해 카드를 꾸미는 코드에 미디어쿼리를 적용해보자.
import React from "react";
import { Card, makeStyles, useMediaQuery} from "@material-ui/core";
const useStyles = makeStyles((theme) => ({
card: {
width: "80%",
height: "20%"
},
cardMobile: {
width: "90%",
height: "10%"
}
}))
const CardContainer = () => {
const classes = useStyles();
const isMobile = useMediaQuery("(max-width: 600px)");
<Card className = {isMobile ? classes.cardMobile : classes.card}></Card>
}
이제 브라우저가 감지한 화면 너비가 600px보다 작으면 모바일용 디자인을 적용할 것이고, 그 이상일 경우에는 데스크탑용 디자인을 적용할 것이다.
반응형
'🎨 프론트엔드 > UI Library' 카테고리의 다른 글
Tailwind CSS : JIT 모드에 대하여 (0) | 2021.10.11 |
---|---|
create-react-app과 Tailwind CSS 함께 사용하기 (3) | 2021.05.27 |
Scss 파일에서 다른 스타일시트 불러오기 (0) | 2021.03.09 |
Comments
소소한 팁 : 광고를 눌러주시면, 제가 뮤지컬을 마음껏 보러다닐 수 있어요!
와!! 바로 눌러야겠네요! 😆