0

TL;博士

如何将包含一个或多个 CSS 规则的变量插入到 styled-jsx 中(在后台使用 styled-jsx-plugin-sass)?


我有以下 JSX 风格:

// src/pages/index.tsx
...
<style jsx>
  {`
    .test {
      height: 100vh;
      width: 100vw;
      background-color: green;
      ${contained}
     }
  `}
</style>

并且contained是我试图将上述规则插入其中的变量:

// src/styles/break.ts

export const contained = `
margin: 0 auto;
${breakAt("sm")(`
  width: calc(100% - 10vw);
`)}
${breakAt("md")(`
  width: calc(100% - 15vw);
`)}
@media screen and (min-width: calc(960px + 10vw)) {
  width: 960px;
}`;
...

笔记:

breakAt是一个生成特定媒体查询的函数(breakpoint: string) => (content: string) => string

我已确保styled-jsx-plugin-sass配置正确 - 按预期以原始行为编写生成的 CSS。

我还研究了我认为 styled-jsx 的行为方式——它似乎对我在编写生成器((content: string) => string作用于contained)并调用它时输入的代码进行了一些文字解析,并且解析器识别出我写了一个CallExpression,但是因此未能渲染任何东西。

我知道这可以通过使用来解决,@mixin/@include但我正在挑选我目前喜欢的 Sass 功能(主要是嵌入式规则),并且很想知道有什么可能。

非常感谢您的输入和更正。请在回答之前阅读完整的问题!

4

1 回答 1

0

我不是styled-components(还!)的粉丝,但这似乎是这种情况下的有效情况:

import styled from "styled-components"
// ... other imports

const Wrapper = styled.div`
  /* ... scoped styles */
  ${contained} /* mixin */
`

export default SomeComponent({ children }) {
  return <Wrapper>This component was mixed in<Wrapper/>
}
于 2021-01-17T23:06:05.217 回答