使用有条件的语句与样式组件
我正在尝试为我的Paymentbtn设计样式,其中包括我的主要样式按钮,但我只希望在激活我的载荷道具时会影响悬停效果,同时使所有内容保持相同,除了悬停效果。有没有办法只能改变悬停效果的样式?
基本的按钮
export const BaseBtn = styled.button`
min-width: 165px;
width: auto;
height: 50px;
letter-spacing: 0.5px;
line-height: 50px;
padding: 0 35px 0 35px;
font-size: 15px;
background-color: black;
color: white;
text-transform: uppercase;
font-family: "Open Sans Condensed";
font-weight: bolder;
border: none;
cursor: pointer;
display: flex;
justify-content: center;
align-items: center;
&:hover {
background-color: white;
color: black;
border: 1px solid black;
}
`;
paymenthbtn样式
export const PaymentBtn = styled(Button)`
margin-left: auto;
margin-top: 30px;
`;
我想要这样的东西,但不知道如何使用样式组件
export const PaymentBtn = styled(Button)`
margin-left: auto;
margin-top: 30px;
&:hover {
${({isLoading}) => isLoading ?
hover:{
background-color: "gray" : "black"
}
}
`;
I'm trying to style my PaymentBtn which includes my main styled Button but I only want the hover effect to be affected when my isLoading prop is activated while keeping everything the same EXCEPT the hover effect. Is there a way to only change the styling on the hover effect?
Basic button
export const BaseBtn = styled.button`
min-width: 165px;
width: auto;
height: 50px;
letter-spacing: 0.5px;
line-height: 50px;
padding: 0 35px 0 35px;
font-size: 15px;
background-color: black;
color: white;
text-transform: uppercase;
font-family: "Open Sans Condensed";
font-weight: bolder;
border: none;
cursor: pointer;
display: flex;
justify-content: center;
align-items: center;
&:hover {
background-color: white;
color: black;
border: 1px solid black;
}
`;
PaymentBtn styles
export const PaymentBtn = styled(Button)`
margin-left: auto;
margin-top: 30px;
`;
I want something like this but don't know how to use it with styled-components
export const PaymentBtn = styled(Button)`
margin-left: auto;
margin-top: 30px;
&:hover {
${({isLoading}) => isLoading ?
hover:{
background-color: "gray" : "black"
}
}
`;
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
您可以尝试以下操作:
当
isloading
是真的,否则,它将显示black
时,这将显示灰色
颜色。如果您不需要false
上的任何颜色,请将其设置为透明
。You can try this:
This will show
gray
color on hover whenisLoading
is true, otherwise, it will showblack
. If you don't want any color onfalse
, set it astransparent
.我认为这可能会起作用
I think this might work
我实际上确实找到了一种有效的方法,我很想用您的解决方案从别人那里听到
I actually did find a method that works and I would love to hear from others with your solution