我正在与React一起开发Web应用程序项目。我在其中将材料ui用于导航栏。在移动设备的右侧有一个显示更多图标。但是,当我打开它时,弹出框在左侧打开,并显示错误Material-UI:提供给组件的anchorEl
道具无效。我想要它在右上方。但是做不到。我该怎么办?
这是代码
import React, { useState } from 'react';
import './Navbar.css'
import { useScrollTrigger, Slide, AppBar, Toolbar, IconButton, makeStyles, Divider, List, ListItem, ListItemIcon, ListItemText, Hidden, Drawer, useTheme, Menu, MenuItem } from '@material-ui/core';
import MenuIcon from '@material-ui/icons/Menu';
import InboxIcon from '@material-ui/icons/MoveToInbox';
import MailIcon from '@material-ui/icons/Mail';
import MoreIcon from '@material-ui/icons/MoreVert';
import Logo from '../../images/logo.png';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { faGithub, faLinkedinIn } from '@fortawesome/free-brands-svg-icons';
const drawerWidth = 240;
const useStyles = makeStyles((theme) => ({
toolbar: theme.mixins.toolbar,
grow: {
flexGrow: 1,
},
menuButton: {
marginRight: theme.spacing(2),
},
sectionDesktop: {
display: 'none',
[theme.breakpoints.up('md')]: {
display: 'flex',
},
},
sectionMobile: {
display: 'flex',
[theme.breakpoints.up('md')]: {
display: 'none',
},
},
drawer: {
[theme.breakpoints.up('sm')]: {
width: drawerWidth,
flexShrink: 0,
},
},
drawerPaper: {
width: drawerWidth,
},
}));
const Navbar = (props) => {
const { window } = props;
const classes = useStyles();
const theme = useTheme();
const [mobileOpen, setMobileOpen] = useState(false);
const [mobileMoreAnchorEl, setMobileMoreAnchorEl] = useState(null);
console.log(mobileMoreAnchorEl);
const HideOnScroll = (props) => {
const { children, window } = props;
const trigger = useScrollTrigger({ target: window ? window() : undefined });
return (
<Slide appear={false} direction="down" in={!trigger}>
{children}
</Slide>
)
}
const handleDrawerToggle = () => {
setMobileOpen(!mobileOpen);
};
const isMobileMenuOpen = Boolean(mobileMoreAnchorEl);
const handleMobileMenuClose = () => {
setMobileMoreAnchorEl(null);
}
const handleMobileMenuOpen = (event) => {
setMobileMoreAnchorEl(event.currentTarget);
}
const mobileMenuId = 'primary-search-account-menu-mobile';
const renderMobileMenu = (
<Menu
anchorEl={mobileMoreAnchorEl}
anchorOrigin={{ vertical: 'top', horizontal: 'right' }}
id={mobileMenuId}
keepMounted
transformOrigin={{ vertical: 'top', horizontal: 'right' }}
open={isMobileMenuOpen}
onClose={handleMobileMenuClose}
>
<MenuItem>
<IconButton color="inherit">
<FontAwesomeIcon icon={faGithub} />
</IconButton>
</MenuItem>
<MenuItem>
<IconButton color="inherit">
<FontAwesomeIcon icon={faLinkedinIn} />
</IconButton>
</MenuItem>
</Menu>
);
const drawer = (
<div>
<div className={classes.toolbar} />
<Divider />
<List>
{['GitHub', 'Started', 'Send email', 'Drafts'].map((text, index) => (
<ListItem button key={text}>
<ListItemIcon>{index % 2 === 0 ? <InboxIcon /> : <MailIcon />}</ListItemIcon>
<ListItemText primary={text} />
</ListItem>
))}
</List>
</div>
)
const container = window !== undefined ? () => window().document.body : undefined;
return (
<div className={classes.grow}>
<div>
<HideOnScroll {...props}>
<AppBar>
<Toolbar>
<IconButton
edge="start"
className={classes.menuButton}
color="inherit"
aria-label="open drawer"
onClick={handleDrawerToggle}
>
<MenuIcon />
</IconButton>
<img className="logo" src={Logo} alt="" />
<div className={classes.grow} />
<div className={classes.sectionDesktop}>
<a style={{ textDecoration: 'none' }} href="https://github.com/muhidhossain">
<IconButton style={{ color: 'aqua', outline: 'none' }}>
<FontAwesomeIcon icon={faGithub} />
</IconButton>
</a>
<IconButton style={{ color: 'aqua', outline: 'none' }}>
<FontAwesomeIcon icon={faLinkedinIn} />
</IconButton>
</div>
<div className={classes.sectionMobile}>
<IconButton
aria-label="show more"
aria-controls={mobileMenuId}
aria-haspopup="true"
onClick={handleMobileMenuOpen}
color="inherit"
>
<MoreIcon />
</IconButton>
</div>
</Toolbar>
</AppBar>
</HideOnScroll>
{renderMobileMenu}
</div>
<nav className={classes.drawer} aria-label="mailbox folders">
<Hidden smUp implementation="css">
<Drawer
container={container}
variant="temporary"
anchor={theme.direction === 'rtl' ? 'right' : 'left'}
open={mobileOpen}
onClose={handleDrawerToggle}
classes={{ paper: classes.drawPaper }}
ModalProps={{ keepMounted: true }}
>
{drawer}
</Drawer>
</Hidden>
</nav>
</div>
);
};
export default Navbar;
答案 0 :(得分:1)
HideOnScroll组件正在创建此问题。对于每次重新渲染,都会重新创建组件。由于锚点指向不再存在的HTML元素,因此会引发错误。如果我们将组件移到Navbar组件之外,则此问题将得到解决。
import React, { useState } from 'react';
import './Navbar.css'
import { useScrollTrigger, Slide, AppBar, Toolbar, IconButton, makeStyles, Divider, List, ListItem, ListItemIcon, ListItemText, Hidden, Drawer, useTheme, Menu, MenuItem } from '@material-ui/core';
import MenuIcon from '@material-ui/icons/Menu';
import InboxIcon from '@material-ui/icons/MoveToInbox';
import MailIcon from '@material-ui/icons/Mail';
import MoreIcon from '@material-ui/icons/MoreVert';
import Logo from '../../images/logo.png';
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import { faGithub, faLinkedinIn } from '@fortawesome/free-brands-svg-icons';
const drawerWidth = 240;
const useStyles = makeStyles((theme) => ({
toolbar: theme.mixins.toolbar,
grow: {
flexGrow: 1,
},
menuButton: {
marginRight: theme.spacing(2),
},
sectionDesktop: {
display: 'none',
[theme.breakpoints.up('md')]: {
display: 'flex',
},
},
sectionMobile: {
display: 'flex',
[theme.breakpoints.up('md')]: {
display: 'none',
},
},
drawer: {
[theme.breakpoints.up('sm')]: {
width: drawerWidth,
flexShrink: 0,
},
},
drawerPaper: {
width: drawerWidth,
},
}));
const HideOnScroll = (props) => {
const { children, window } = props;
const trigger = useScrollTrigger({ target: window ? window() : undefined });
return (
<Slide appear={false} direction="down" in={!trigger}>
{children}
</Slide>
)
}
const Navbar = (props) => {
const { window } = props;
const classes = useStyles();
const theme = useTheme();
const [mobileOpen, setMobileOpen] = useState(false);
const [mobileMoreAnchorEl, setMobileMoreAnchorEl] = useState(null);
console.log(mobileMoreAnchorEl);
const handleDrawerToggle = () => {
setMobileOpen(!mobileOpen);
};
const isMobileMenuOpen = Boolean(mobileMoreAnchorEl);
const handleMobileMenuClose = () => {
setMobileMoreAnchorEl(null);
}
const handleMobileMenuOpen = (event) => {
setMobileMoreAnchorEl(event.currentTarget);
}
const mobileMenuId = 'primary-search-account-menu-mobile';
const renderMobileMenu = (
<Menu
anchorEl={mobileMoreAnchorEl}
anchorOrigin={{ vertical: 'top', horizontal: 'right' }}
id={mobileMenuId}
keepMounted
transformOrigin={{ vertical: 'top', horizontal: 'right' }}
open={isMobileMenuOpen}
onClose={handleMobileMenuClose}
>
<MenuItem>
<IconButton color="inherit">
<FontAwesomeIcon icon={faGithub} />
</IconButton>
</MenuItem>
<MenuItem>
<IconButton color="inherit">
<FontAwesomeIcon icon={faLinkedinIn} />
</IconButton>
</MenuItem>
</Menu>
);
const drawer = (
<div>
<div className={classes.toolbar} />
<Divider />
<List>
{['GitHub', 'Started', 'Send email', 'Drafts'].map((text, index) => (
<ListItem button key={text}>
<ListItemIcon>{index % 2 === 0 ? <InboxIcon /> : <MailIcon />}</ListItemIcon>
<ListItemText primary={text} />
</ListItem>
))}
</List>
</div>
)
const container = window !== undefined ? () => window().document.body : undefined;
return (
<div className={classes.grow}>
<div>
<HideOnScroll {...props}>
<AppBar>
<Toolbar>
<IconButton
edge="start"
className={classes.menuButton}
color="inherit"
aria-label="open drawer"
onClick={handleDrawerToggle}
>
<MenuIcon />
</IconButton>
<img className="logo" src={Logo} alt="" />
<div className={classes.grow} />
<div className={classes.sectionDesktop}>
<a style={{ textDecoration: 'none' }} href="https://github.com/muhidhossain">
<IconButton style={{ color: 'aqua', outline: 'none' }}>
<FontAwesomeIcon icon={faGithub} />
</IconButton>
</a>
<IconButton style={{ color: 'aqua', outline: 'none' }}>
<FontAwesomeIcon icon={faLinkedinIn} />
</IconButton>
</div>
<div className={classes.sectionMobile}>
<IconButton
aria-label="show more"
aria-controls={mobileMenuId}
aria-haspopup="true"
onClick={handleMobileMenuOpen}
color="inherit"
>
<MoreIcon />
</IconButton>
</div>
</Toolbar>
</AppBar>
</HideOnScroll>
{renderMobileMenu}
</div>
<nav className={classes.drawer} aria-label="mailbox folders">
<Hidden smUp implementation="css">
<Drawer
container={container}
variant="temporary"
anchor={theme.direction === 'rtl' ? 'right' : 'left'}
open={mobileOpen}
onClose={handleDrawerToggle}
classes={{ paper: classes.drawPaper }}
ModalProps={{ keepMounted: true }}
>
{drawer}
</Drawer>
</Hidden>
</nav>
</div>
);
};
export default Navbar;