首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >MUI没有正确地将主题传递给MUI组件。

MUI没有正确地将主题传递给MUI组件。
EN

Stack Overflow用户
提问于 2021-10-02 19:08:22
回答 1查看 4.6K关注 0票数 6

我已经在我的React.JS项目的索引中使用MUI创建了一个主题。当我尝试将我的样式应用于我的Appbar时,主题没有正确地修改菜单按钮或菜单本身。该按钮看起来是通用默认的,当它与Appbar本身的颜色匹配时,菜单仍然是白色的。

我的index.tsx看起来是这样的:

代码语言:javascript
复制
import React from "react";
import ReactDOM from "react-dom";
import AppbarTop from "./AppbarTop";
import { Router } from "react-router";
import { createBrowserHistory } from "history";
import AdapterDateFns from "@mui/lab/AdapterDateFns";
import { LocalizationProvider } from "@mui/lab";
import { createTheme } from "@mui/material";
import { ThemeProvider } from "@mui/styles";
import { StyledEngineProvider } from "@mui/material/styles";

const customHistory = createBrowserHistory();

const theme = createTheme({
  palette: {
    primary: {
      main: "#242526"
    },
    secondary: {
      main: "#d975d0"
    },
    text: {
      primary: "#E4E6EB",
      secondary: "#B0B3B8"
    },
    background: {
      default: "#242526",
      paper: "#242526"
    }
  }
});

ReactDOM.render(
  <React.StrictMode>
    <LocalizationProvider dateAdapter={AdapterDateFns}>
      <Router history={customHistory}>
        <ThemeProvider theme={theme}>
          <StyledEngineProvider injectFirst>
            <AppbarTop />
          </StyledEngineProvider>
        </ThemeProvider>
      </Router>
    </LocalizationProvider>
  </React.StrictMode>,
  document.getElementById("root")
);

我的appbar.tsx看起来是这样的:

代码语言:javascript
复制
import React from "react";
import {
  AppBar,
  Box,
  Button,
  Container,
  Menu,
  MenuItem,
  Toolbar
} from "@mui/material";
import HomeIcon from "@mui/icons-material/Home";
import { makeStyles } from "@mui/styles";

const useStyles = makeStyles((theme?: any) => ({
  appBar: {
    background: theme.palette.primary.main,
    height: "60px",
    position: "relative"
  }
}));

const AppbarTop: React.FC<{ [key: string]: any }> = () => {
  const classes = useStyles();

  const [anchorEl, setAnchorEl] = React.useState<any>(null);
  const open = Boolean(anchorEl);
  const handleClick = (event: React.MouseEvent<HTMLButtonElement>) => {
    setAnchorEl(event.currentTarget);
  };
  const handleClose = () => {
    setAnchorEl(null);
  };

  return (
    <>
      <AppBar position="static" className={classes.appBar}>
        <Toolbar>
          <Button
            id="basic-button"
            aria-controls="basic-menu"
            aria-haspopup="true"
            aria-expanded={open ? "true" : undefined}
            onClick={handleClick}
          >
            Dashboard
          </Button>
          <Menu
            id="basic-menu"
            anchorEl={anchorEl}
            open={open}
            onClose={handleClose}
            MenuListProps={{
              "aria-labelledby": "basic-button"
            }}
          >
            <MenuItem onClick={handleClose}>
              <HomeIcon />{" "}
            </MenuItem>
          </Menu>
          {/*test speed dial*/}

          <Container maxWidth="sm"></Container>
          <Box></Box>
        </Toolbar>
      </AppBar>
    </>
  );
};

export default AppbarTop;

有人能解释一下我错过了什么吗?

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-10-02 19:36:58

更改这一行:

代码语言:javascript
复制
import { ThemeProvider } from "@mui/styles";

至:

代码语言:javascript
复制
import { ThemeProvider } from "@mui/material/styles";

原因:这里有两个ThemeProvider

  • @梅/风格:这个ThemeProvider确实通过上下文发送Theme对象,它运行良好,您仍然可以使用useTheme钩子访问它:
代码语言:javascript
复制
const theme = useTheme();

return <Box sx={{ width: 10, height: 10, bgcolor: theme.palette.primary.main }} />
  • @mui/material/stylesThemeProvider是上述内容的包装器,但它也将主题注入到StyledEngineThemeContext.Provider中,这允许您在使用MUI (sx prop/styled())时访问主题。这里的问题是,ButtonMenu组件使用,即底层styled() API,因此需要从@mui/material/styles导入ThemeProvider以使其工作。
代码语言:javascript
复制
return <Box sx={{ width: 10, height: 10, bgcolor: 'primary.main' }} />

相关答案

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

https://stackoverflow.com/questions/69419447

复制
相关文章

相似问题

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