Chi*_*Chi 2 typescript reactjs tailwind-css
我制作了一个 MessageBanner 组件,并想从中制作多个横幅,例如 MessageSuccess(绿色主题)和 MessageError(红色主题)。我尝试传递背景颜色、文本颜色和边框颜色的类名,但没有成功。请帮忙。
这是 MessageBanner.tsx。
export const MessageBanner: VFC<Props> = memo(props => {
const { title, description, bgColor, textColor, borderColor } = props
return (
<>
<div
className={`${bgColor} ${textColor} ${borderColor} pointer-events-autoborder-t-4 rounded-b px-4 py-3 shadow-md duration-1000`}
role='alert'
>
<div className='flex'>
<div>
<p className='font-bold'>{title}</p>
<p className='text-sm'>{description}</p>
</div>
</div>
</div>
</>
)
})
Run Code Online (Sandbox Code Playgroud)
这是 MessageSuccess 组件。我尝试不使用“.”,例如使用“bg-green-100”而不是“.bg-green-100”,但都没有成功。
export const MessageSuccess: VFC = () => {
return (
<MessageBanner
title='Welcome Back'
description='You have successfully logged in'
bgColor='.bg-green-100'
textColor='.green-900'
borderColor='.border-green-500'
/>
)
}
Run Code Online (Sandbox Code Playgroud)
我很感激任何帮助。提前致谢。
您可能想要开始使用classnames包,这样您就可以更轻松地使用条件类,但主要问题是您已包含.在类名称中:这些名称仅在类定义/查询选择器中使用,而不是在您使用条件类时使用。分配类,所以:
export const MessageSuccess: VFC = () => {
return (
<MessageBanner
title='Welcome Back'
description='You have successfully logged in'
bgColor='bg-green-100'
textColor='green-900'
borderColor='border-green-500'
/>
)
}
Run Code Online (Sandbox Code Playgroud)
没有.这三个属性。然后,你可以这样做:
import { classnames } from "classnames";
const MessageBanner = (props) => {
const classStr = classnames(
"pointer-events-autoborder-t-4 rounded-b px-4 py-3 shadow-md duration-1000",
props.bgColor,
props.textColor,
props.borderColor
);
return <div className={classStr} role="alert">{props.description}</div>
};
export { MessageBanner }
Run Code Online (Sandbox Code Playgroud)
一切都应该很好。