React styled-components
설치법
npm i styled-components
이용법
import styled from "styled-components"
사용 방법
const Father = styled.div`
display: flex;
`;
const 이름 = styled.{htmltag 이름}` //<=(백틱)
css 내용
`;
function App() {
return (
<div className="App">
<Father>
</Father>
</div>
);
}
Adapting(적응) ,중복되는 css 내용에 속성만 변경하는 방법
import styled from "styled-components";
const Father = styled.div`
display: flex;
`;
const Box = styled.div`
background-color: ${(props) => props.bgColor};
width: 100px;
height: 100px;
`;
function App() {
return (
<div className="App">
<Father>
<Box bgColor="gray" />
<Box bgColor="tomato" />
</Father>
</div>
);
}
export default App;
변수로 두고 싶은 css 코드에 ${props=>props.변수이름} 을 둔 후
<Box 변수이름="변수내용">
이렇게 사용하면 됩니다.
Extending (확장), 중복되는 css 내용에 속성을 추가하는 방법
import styled from "styled-components";
const Father = styled.div`
display: flex;
`;
const Box = styled.div`
background-color: ${(props) => props.bgColor};
width: 100px;
height: 100px;
`;
const Circle = styled(Box)`
border-radius: 50px;
`;
function App() {
return (
<div className="App">
<Father>
<Box bgColor="gray" />
<Circle bgColor="tomato" />
</Father>
</div>
);
}
export default App;
어떤 css 내용에 다른 속성만 추가해서 사용하고 싶을 때는
const 변수이름 = styled(중복해서 사용하고자하는 css이름)`
추가되는 css 코드
`;
이렇게 사용하면 됩니다.
as(같이) , 기존의 css 코드를 사용하되 htmlTag를 변경하고 싶을 때
import styled from "styled-components";
const Father = styled.div`
display: flex;
`;
const Btn = styled.button`
background-color: tomato;
color: white;
width: 100px;
height: 50px;
border-radius: 20px;
font-size: 18px;
display: flex;
justify-content: center;
align-items: center;
`;
function App() {
return (
<div className="App">
<Father>
<Btn>Click Me</Btn>
<Btn as="a" href="/">
Click Me
</Btn>
</Father>
</div>
);
}
export default App;
Btn 이라는 변수를 만들었지만 button 태그말고 a 태그로도 사용하고 싶을 때는
<Btn as="a" href="/"></Btn> 처럼
as 를 추가하면 다른태그로 변경할 수 있습니다.
atters ,(attribute 속성) , 변수에 어떠한 속성을 고정적으로 주고 싶을 때
import styled from "styled-components";
const Father = styled.div`
display: flex;
flex-direction: column;
`;
const Input = styled.input.attrs({ required: true, minLength: 10 })`
background-color: tomato;
color: white;
width: 100px;
height: 50px;
border-radius: 20px;
font-size: 18px;
display: flex;
justify-content: center;
align-items: center;
`;
function App() {
return (
<div className="App">
<Father>
<Input />
<Input />
<Input />
<Input />
<Input />
<Input />
</Father>
</div>
);
}
export default App;
input을 많이 사용하는데 각각마다 required를 계속 붙이는 것 보다 attrs로 해당 변수에 고정적인 속성내용을 부여할 수 있다.
const 변수이름 = styled.div.attrs({ 속성 EX: required:true, minLength : 10})`
css 코드내용
`;
Animation , 애니메이션 주는 방법
import styled, { keyframes } from "styled-components";
const Father = styled.div`
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
height: 100vh;
`;
const rotateAni = keyframes`
0%{
transform:rotate(0deg);
border-radius:0px
}50%{
transform: rotate(360deg);
border-radius:50%
}100%{
transform: rotate(0deg);
border-radius:0px;
}
`;
const Box = styled.div`
background-color: tomato;
width: 300px;
height: 300px;
animation: ${rotateAni} linear 1s infinite;
`;
function App() {
return (
<div className="App">
<Father>
<Box></Box>
</Father>
</div>
);
}
export default App;
const 변수이름 = keyframes`
css 내용
`;
을 하면 애니메이션을 만들 수 있습니다.
사용할때는 사용하고자하는 대상 css 코드에서
animation : ${애니메이션 변수이름} css코드
로 사용할 수 있습니다.
pesudo selector , 특정 태그 선택하는 방법
import styled, { keyframes } from "styled-components";
const Father = styled.div`
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
height: 100vh;
`;
const Box = styled.div`
background-color: tomato;
width: 300px;
height: 300px;
display: flex;
justify-content: center;
align-items: center;
span {
font-size: 50px;
&:hover {
font-size: 100px;
}
&:active {
opacity: 0;
}
}
`;
function App() {
return (
<div className="App">
<Father>
<Box>
<span>😍</span>
</Box>
</Father>
</div>
);
}
export default App;
변수안에 있는 태그를 특정지어서 선택하고 싶을 때
예를들어
<Box>
<span>😍</span>
</Box>
이렇게 있는 span을 선택하고 싶을 때
const Box = styled.div`
css 코드
span{
css 코드
&:hover{
css코드
}
}
`
이렇게 사용 가능합니다.
기본적으로 sass 와 비슷합니다.
if문처럼 특정조건에서만 css 내용이 필요할 때
import styled, { keyframes } from "styled-components";
const Father = styled.div`
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
height: 100vh;
`;
const Emoji = styled.span`
font-size: 50px;
`;
const Box = styled.div`
background-color: tomato;
width: 300px;
height: 300px;
display: flex;
justify-content: center;
align-items: center;
${Emoji} {
font-size: 50px;
&:hover {
font-size: 100px;
}
&:active {
opacity: 0;
}
}
`;
function App() {
return (
<div className="App">
<Father>
<Box>
<Emoji>😍</Emoji>
</Box>
<Emoji>😍</Emoji>
</Father>
</div>
);
}
export default App;
Box 안에 ${Emoji}로 css 내용을 추가하였는데
밑에 Emoji 자체로는 hover가 적용 되지 않지만 Box 안에 있을 때 적용된다는 식으로 if문처럼 사용할 수 있습니다.
Theme Provider , 다크모드,라이트모드 테마 변경하기
이용법
App, index 에 Provider을 import 해줍니다.
import { ThemeProvider } from "styled-components";
사용법
1.App을 ThemeProVider로 감싸줍니다.
ReactDOM.render(
<React.StrictMode>
<ThemeProvider theme={lightTheme}>
<App />
</ThemeProvider>
</React.StrictMode>,
document.getElementById("root")
);
2. dark , light css 코드를 index.js 에 적어줍니다. 각각의 프로퍼티의 이름은 같아야 합니다. textColor, backgroundColor
import React from "react";
import ReactDOM from "react-dom";
import { ThemeProvider } from "styled-components";
import App from "./App";
const darkTheme = {
textColor: "whitesmoke",
backgroundColor: "#111",
};
const lightTheme = {
textColor: "#111",
backgroundColor: "whitesmoke",
};
ReactDOM.render(
<React.StrictMode>
<ThemeProvider theme={lightTheme}>
<App />
</ThemeProvider>
</React.StrictMode>,
document.getElementById("root")
);
3.App.js 에서 변환시키고자하는 부분에 props.theme.textColor or backgroundColor 등을 입력해줍니다
import styled, { keyframes, ThemeProvider } from "styled-components";
const Father = styled.div`
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
height: 100vh;
background-color: ${(props) => props.theme.backgroundColor};
`;
const Title = styled.span`
color: ${(props) => props.theme.textColor};
font-size: 24px;
`;
function App() {
return (
<div className="App">
<Father>
<Title>Hello</Title>
</Father>
</div>
);
}
export default App;
공부하며 느낀 점
기존에 사용하던 css , <App styles={{backgroundColor:"tomato"}}>, App.module.css , sass 등과는 비교할 수 없을정도로 많은 장점을 가지고 있는 것 같아 감동을 받았습니다.