Typescript와 함께 동적 CSS 스타일 사용하기
data:image/s3,"s3://crabby-images/a3101/a3101794d7a1c21902bcfdbad3f13c2d78abd908" alt=""
import styled from "@emotion/styled"; const StyledPropsTest = styled.div` width: 120px; height: 40px; font-size: 25px; background: ${(props) => (props.testProps ? "blue" : "red")}; color: white; `; const StyledTest = ({testprops}) => { return( <StyledPropsTest testProps={testprops}>Prop Test</StyledPropsTest> ) } export default StyledTest;
컴포넌트 내부에서 사용하는 변수를 CSS에 전달하여 동적 스타일을 적용하기 위해서는 위와 같이 props를 전달하는 방법이 있습니다.
하지만 Typescipt를 사용하여 custom props를 사용하면 다음과 같은 에러를 만나게 됩니다.
data:image/s3,"s3://crabby-images/4d34a/4d34a30bc8e05d1f1f1ac10042745e6875304fc9" alt=""
(property) testProps: boolean
Type ‘{ children: string; testProps: boolean; }’ is not assignable to type ‘IntrinsicAttributes & { theme?: Theme | undefined; as?: ElementType<any> | undefined; } & ClassAttributes<HTMLDivElement> & HTMLAttributes<…>’.
Property ‘testProps’ does not exist on type ‘IntrinsicAttributes & { theme?: Theme | undefined; as?: ElementType<any> | undefined; } & ClassAttributes<HTMLDivElement> & HTMLAttributes<…>’.ts(2322)
이는 타입스크립트에서 props의 타입을 체크하기 때문인데요.
다음과 같이 간단하게 <{data:type}>의 타입 단언(Type Assertion)으로 해결할 수 있습니다.
const StyledPropsTest = styled.div<{testProps:boolean}>` width: 120px; height: 40px; font-size: 25px; background: ${(props) => (props.testProps ? "blue" : "red")}; color: white; `;
다음과 같이 에러가 사라진 것을 확인할 수 있습니다.
data:image/s3,"s3://crabby-images/6a41a/6a41a96fb6349b0a5fbdc489f07e2e3d3d9b59a7" alt=""
data:image/s3,"s3://crabby-images/6da01/6da01d27c762541ae7996c0aaae7be518b7012ac" alt=""