首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >我可以使用React中的样式组件实现以下条件媒体查询吗?

我可以使用React中的样式组件实现以下条件媒体查询吗?
EN

Stack Overflow用户
提问于 2018-03-12 20:12:53
回答 2查看 1.5K关注 0票数 0

我正在尝试将wrapper类添加到React中的样式组件中。有没有我可以实现它的方法,这样就可以像下面这样生成CSS?

代码语言:javascript
复制
.test-class {
    color: red;
    font-size: 40px;
}

@media (max-width: 600px) {
    .wrapper .test-class { 
       color: blue;
       font-size: 30px;
    }
}

像这样的东西

代码语言:javascript
复制
const Content = styled.div`
    color: red;
    font-size: 40px;

    @media (max-width: 600px) {
       .wrapper {
            color: blue;
            font-size: 30px;
       }
    } 
`;

谢谢!

EN

回答 2

Stack Overflow用户

发布于 2018-03-12 21:05:34

以下是执行此操作的示例模板

代码语言:javascript
复制
const Content = styled.div`
  background: papayawhip;
  height: 3em;
  width: 3em;

  @media (max-width: 700px) {
    background: palevioletred;
  }
`;

render(
  <Content />
);

有关详细信息,请参阅- https://www.styled-components.com/docs/advanced

票数 0
EN

Stack Overflow用户

发布于 2018-03-17 22:06:29

您可以创建媒体查询文件或/并添加以下代码

代码语言:javascript
复制
const size = {
  tablet: '600px',
}
const device = {
  yourSize: `(max-width: ${size.tablet})`,
}

并通过使用选择器来引用包装器下的测试类来更改样式组件类,如下所示

代码语言:javascript
复制
const TestClass = styled.div`
  color: red;
  font-size: 40px;
`;
const Wrapper = styled.div`
  @media ${device.yourSize}  {  
    ${TestClass} {
      color: blue;
      font-size: 30px;
    }
  }
`;

 render(
  <Wrapper>
    <TestClass>Text</TestClass>
  </Wrapper>
 );
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49234979

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档