样式组件从字符串 prop 中获取值

cdmt

这里有一个演示

我正在尝试使用样式组件创建列布局

我试图传递道具中列的宽度。

是否可以从传递给组件的 srig prop 中获取值

所以如果我通过

<PageLayout twoCol="60,40">

我想得到类似的值

flex-basis: ${props.twoCol.split(',')[0]}'%';

我认为它是 s 字符串,所以我可以使用 split 来获取字符串中的单独值。

这不起作用。有没有另一种方法可以做到这一点。

丹尼斯·瓦什

你当然可以:

const PageLayout = styled.div`
  flex-basis: ${(props) => props.twoCol.split(",")[0]}%;
`;

但更好的选择可能是传递值而不是操作字符串:

<PageLayout twoCol={[60,40]}>

const PageLayout = styled.div`
  flex-basis: ${(props) => props.twoCol[0]}%;
`;

您的代码段的主要问题是您需要在字符串文字中编写一个真正的CSS

// not '%' like ${(props) => props.someProp}'%'
flex-basis: ${(props) => props.someProp}%;

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章