我还是很新的这个,所以原谅我,如果它不是最好的答案。我觉得为每个应用定义不同的主题可能是实现您想要的结果的有用方法。做这样的事情
export default {
spacing: spacing,
fontFamily: 'Roboto, sans-serif',
palette: {
primary1Color: cyan500,
primary2Color: cyan700,
primary3Color: grey400,
accent1Color: pinkA200,
accent2Color: grey100,
accent3Color: grey500,
textColor: darkBlack,
alternateTextColor: white,
canvasColor: white,
borderColor: grey300,
disabledColor: fade(darkBlack, 0.3),
pickerHeaderColor: cyan500,
clockCircleColor: fade(darkBlack, 0.07),
shadowColor: fullBlack,
},
};
只是当您调用主题提供程序时加载到您的不同应用程序时提供了不同的mUI主题。
<MuiThemeProvider muiTheme={YOUR-THEME-HERE}>
<AppBar title="My AppBar" />
</MuiThemeProvider>
mUI Theme Doc
希望这有助于至少一点点。
我遇到的问题是,当我渲染第二个应用程序时,它会重新创建所有css(因此c1会被重新写入与以前完全不同的东西),但旧组件仍然存在。所以他们的CSS得到了全部的重击。我发现安装'react-jss'并将每个应用程序包装在其中,然后使用'classNamePrefix =“app1”'帮助了大部分内容。尽管如此,仍然有点混乱 – John