reactjs - 如何在库组件和我的应用程序组件之间共享上下文?
问题描述
我正在使用 lerna 创建一个 monorepo,其中我有这样的结构:
root
packages
application - Our root application
components - Just some react components, that are to be used by the application
我遇到的问题是我正在使用 Material-UI 及其主题功能,在应用程序根目录中我们将有一个 ThemeProvider:
import { ThemeProvider } from '@material-ui/styles';
//...
function App() {
return (
<ThemeProvider theme={theme}>
<MyMaterialComponent/>
</ThemeProvider>
);
}
稍后在库组件中,我们使用主题,在我们的例子中使用makeStyles
钩子。
import React from 'react';
import { makeStyles } from '@material-ui/styles';
import Card from "@material-ui/core/Card";
const useStyles = makeStyles(theme => {
console.log(theme); //When this component doesn't have access to the theme, this is `{}`
return {
root: {
//color: theme.palette.primary.main //will error
}
}
});
export function MyMaterialComponent({ }) {
const classes = useStyles();
return (<Card>
<span className={classes.root}>This is some component</span>
</Card>
);
}
现在这似乎很简单。当我们在同一个包中运行此代码时,它工作正常。该样式功能可以访问主题。
但是当我从另一个包(我们的应用程序包)运行时,组件库不再有权访问主题(主题只是一个空对象)。
我目前知道如何解决这个问题的唯一方法,与我解决类似钩子问题的方法相同,即在我的应用程序中设置 webpack 别名配置,以指导组件库共享相同的节点模块。(请参阅此 Github 线程和建议的解决方案)。
IE。使用 react-app-rewired 和 customize-cra 我有一个 config-overrides.js 看起来像这样:
const {
override,
addWebpackAlias,
} = require("customize-cra");
const path = require('path');
module.exports = override(
addWebpackAlias({
react: path.resolve('./node_modules/react'),
//comment out the line below to reproduce the issue
"@material-ui/styles": path.resolve("./node_modules/@material-ui/styles")
})
)
或者你可以手动管理你的 webpack 来做类似的事情。
所以这很好用,但这不是一个特别令人满意的解决方案。
特别是对于像 Material-UI 这样的库,您希望用户能够使用您的组件库,而不会让他们弄乱他们的 webpack 配置。
所以我想我一定是在这里做错了什么——你能告诉我什么吗?
解决方案
您可以通过将@material-ui/core
devDependencies 到 peerDependencies 的依赖项放在库的项目中来实现这一点。就我而言,这解决了我的问题。
有关 peerDependencies 的更多信息:
https://classic.yarnpkg.com/en/docs/dependency-types/#toc-peerdependencies
推荐阅读
- c - 为什么 ptrace 写入 0xFFFFFFFFFFFFFFFF 而不是真实数据?
- r - R 包 API 示例
- excel - VBA 模块覆盖值
- javascript - 在 Javascript 中使用正则表达式提取姓名和电子邮件
- pywinauto - print_control_identifiers | UnicodeEncodeError:“charmap”编解码器无法在位置 21 编码字符“\ue72b”:字符映射到
- angularjs - 如何使用角度 nodejs express 更新 mongodb 中的数据
- android - 检测 RecyclerView 是否可滚动
- amazon-web-services - 如何根据连续传入数据的秒数保存数据
- c# - 在其他计算机上使用带有 CsvHelper 库的项目
- r - 来自 Azure DevOps 的 RStudio 安装包