首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用样式组件重用ThemeProvider?

如何使用样式组件重用ThemeProvider?
EN

Stack Overflow用户
提问于 2019-11-07 20:17:49
回答 1查看 1.1K关注 0票数 1

我在用纱线工作区构建的单一功能中使用样式化的组件。文件夹结构如下所示:

代码语言:javascript
复制
- packages
  - package-a
  - package-b
  - theme

theme中,我导出了如下所示的默认ThemeProvider

代码语言:javascript
复制
const defaultTheme = { ... };

export default function ThemeProvider({ children }) {
  return <StyledThemeProvider theme={defaultTheme}>{children}</StyledThemeProvider>;
}

这段代码会被@babel/预设-反应转换。输出是在package-apackage-b中导入的(两者都是创建-反应-应用程序项目),并作为顶级组件添加。

但是,当试图在这两个包中重用主题时,我会遇到这个错误:

index.js:1375 Component styled.div (..sc fzXfNf)在其样式中使用"props.theme“,但没有通过道具或ThemeProvider提供任何主题。

我记录了propstheme对象是空的({})。为什么会这样呢?我能在这里做我想做的事吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2019-11-13 17:59:12

似乎我只是错误地在这两个包中使用了不同版本的React。我同步了我的依赖项,清除了node_modules,现在我编写的代码运行良好:

代码语言:javascript
复制
const defaultTheme = { ... };

export default function ThemeProvider({ children }) {
  return <StyledThemeProvider theme={defaultTheme}>{children}</StyledThemeProvider>;
}

注意:这是在纱线工作区内,不确定这与其他工具是如何工作的。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58756329

复制
相关文章

相似问题

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