如何在没有 ThemeProvider 的情况下使用 MUI v5 makeStyles?

IT技术 reactjs material-ui jss
2021-03-24 03:38:54

我有一个styles.tsx文件,因为我不想将样式放在我的组件中:

//styles.tsx

import {grey, purple} from '@mui/material/colors';
import {styled, Theme} from '@mui/material/styles';
import {createStyles, makeStyles} from '@mui/styles';

export const drawerStyles = makeStyles((theme: Theme) =>
  createStyles({
    logo: {
      'fontSize': '2em',
      'fontFamily': 'Oleo Script Swash Caps',
      'background': 'transparent',
      'border': 'none',
      'marginLeft': theme.spacing(1),
      'width': '41px',
      'overflow': 'hidden',
      'transition': 'all 0.1s ease-out',
      'cursor': 'pointer',
      '&:hover': {
        color: purple[700],
      },
    },
    slide: {
      paddingLeft: '8px',
      width: '100%',
    },
  }),
);

在另一个组件中,我导入了drawerStyles

// drawerContainer.tsx

import {drawerStyles} from 'Src/styles';

export const DrawerContainer = () => {
  const classes = drawerStyles();

  return (
    <Box className={`${classes.logo}>
      <p>some text</p>
    </Box>
  )

代码编译但浏览器返回错误:

MUI:styles提供参数无效。您在上下文中提供没有主题的功能。父元素之一需要使用 ThemeProvider。

在我的index.tsx我使用ThemeProvider

// index.tsx

import {ThemeProvider, StyledEngineProvider} from '@mui/material/styles';
import {theme} from 'Src/theme';

  const Root = () => {
    return (
      <ApolloProvider client={client}>
        <StyledEngineProvider injectFirst>
          <ThemeProvider theme={theme}>
            <CssBaseline>
              <App />
            </CssBaseline>
          </ThemeProvider>
        </StyledEngineProvider>
      </ApolloProvider>
    );
  };

  render(<Root />, document.getElementById('root'));

我认为问题是因为styles.tsx不在index.tsx范围内。所以当浏览器加载文件时它没有 themeprovider 上下文。

我应该移动组件中的所有样式吗?或者还有其他方法吗?

// 编辑 //

使用样式化的 api 创建样式:

// styles.tsx

export const Logo = styled(Box)(({theme}) => ({
  'fontSize': '2em',
  'fontFamily': 'Oleo Script Swash Caps',
  'background': 'transparent',
  'border': 'none',
  'marginLeft': theme.spacing(1),
  'width': '41px',
  'overflow': 'hidden',
  'transition': 'all 0.1s ease-out',
  'cursor': 'pointer',
  '&:hover': {
    color: purple[700],
  },
}));
// DrawerContainer.tsx

  <Link data-cy='btn_home' to='/'>
    <Logo component='button'>Movieseat</Logo>
  </Link>

我有点不喜欢这种语法,不清楚对象Logo什么类型

1个回答

有关更多详细信息,请参阅答案。简而言之,makesStyles/withStyles不再是 MUI v5 中的第一类 API,并计划在 v6 中删除。如果使用旧 API,则必须自己添加主题。

在 v4 中,您可以导入makeStylesfrom@material-ui/core/styles而无需提供自定义主题。您可以在 v5 中执行相同操作,但只能使用所有 MUI 组件在内部使用的新styledAPI

@PeterBoomsma 你有什么问题styled(),你还有同样的错误吗?
2021-06-04 03:38:54
没有错误。一切都按预期工作。只是想知道这种使用styled()组件的方法是否有意义。
2021-06-15 03:38:54
Styled api 使用添加的样式创建了一个新组件,对吗?我已经用我现在的编码方式更新了我的问题,你能看看吗?
2021-06-16 03:38:54
@PeterBoomsma 对我来说看起来不错。styled/ sxprop 是 v5 中推荐使用的 2 个 API。如果您想在使用typescript时添加道具类型。看到我一个小时前刚写的这个答案。阅读文档部分以了解有关它们的更多信息。
2021-06-17 03:38:54