我已经尝试了css-in-js的迷人的图书馆,不能把我的头脑围绕在一件事上。
使用普通css,您可以轻松地将样式添加到类中的所有选择器中,例如:
.my-awesome-class div {
margin-right: 10px;
}有什么方法可以用迷人的方式来实现它吗?例如,在这个片段中,我正在寻找一种方法来声明容器中的所有div都应该有一个20 it的margin-right,而不需要将它传递给每个组件:
import React from 'react';
import { render } from 'react-dom';
import glamorous, {Div} from 'glamorous';
const Container = glamorous.div({
display: 'flex'
});
class App extends React.Component {
render() {
return (
<Container>
<Div backgroundColor="tomato" padding="10px">One</Div>
<Div backgroundColor="wheat" padding="10px">Two</Div>
<Div backgroundColor="salmon" padding="10px">Three</Div>
</Container>
);
}
}
render(<App />, document.getElementById('root'));下面是一个指向工作片段的链接:https://stackblitz.com/edit/glemorouschildselector
发布于 2017-08-16 11:51:57
迷人的组件工厂风格的论点是由魅力驱动的,它支持上下文选择器。
上下文选择器:&将被指向目标规则的“指针”替换
const Container = glamorous.div(
{
display: 'flex',
'& div': {
marginRight: '20px',
},
},
)魅力选择器文档:https://github.com/threepointone/glamor/blob/master/docs/selectors.md
工作演示:https://stackblitz.com/edit/glemorouschildselector-fzj77j
https://stackoverflow.com/questions/45649078
复制相似问题