材质 ui 中的 <Grid> 导致水平滚动 - React

IT技术 reactjs grid-layout material-ui
2021-04-26 09:18:37

我正在使用Material-UI通过此命令安装的版本 1:

npm install -S material-ui@next

每次我想使用时,页面中都会出现不需要的水平滚动条。

代码:

import React from 'react';
import PropTypes from 'prop-types';
import { withStyles, createStyleSheet } from 'material-ui/styles';
import Paper from 'material-ui/Paper';
import Grid from 'material-ui/Grid';


/* project imports */
import NavMenu from './Page-Parts/NavMenu';
import LoginPanel from './Login-Parts/LoginPanel';

const styleSheet = createStyleSheet('FullWidthGrid', theme => ({
  root: {
    flexGrow: 1,
    marginTop: 0,
  },
  paper: {
    padding: 16,
    textAlign: 'center',
    color: theme.palette.text.secondary,
    marginTop: "3rem"
  },
}));

function Login(props) {
    const classes = props.classes;
    return (
    <div className={classes.root}>
      <Grid container gutter={24} justify='center'>
        <Grid item xs={12} md={12} sm={12} lg={12}>
          <NavMenu/>
        </Grid>
        <Grid item xs={6} sm={6} md={6} lg={6}>
          <Paper className={classes.paper}>
            <LoginPanel />
          </Paper>
        </Grid>
      </Grid>
    </div>
    );
}

Login.propTypes = {
  classes: PropTypes.object.isRequired,
};

export default withStyles(styleSheet)(Login);

Bootstrap和其他grid layout选项与此库冲突。当我<Grid>在组件的其他部分(例如在抽屉中)使用时,出现水平滚动会使 UI 变得丑陋, NavMenu并且LoginPanel是一些自制组件,它们可以正常工作并且使用它们不会导致水平滚动。

4个回答

我遇到过同样的问题。我想出了几个解决方案,但都不觉得很优雅:

禁用间距
不幸的是,这会从容器内的子网格项中删除所有填充:

<Grid container
  spacing={0}>

手动修复 CSS
这就是我最终做的:

<Grid container
  style={{
    margin: 0,
    width: '100%',
  }}>

从评论中复制了简单的解决方案:

添加xs={12}<Grid container>

<Grid container spacing={3} xs={12}>

归功于https://github.com/mui-org/material-ui/issues/7466#issuecomment-509150645

这是由spacing. 有时我们仍然可以spacing通过限制一个Container下的Grid来使用

<Container maxWidth={false}>
  <Grid container spacing={6}>
    Omit
  </Grid>
</Container>

这里最好的解决方案是将网格包裹在具有最大宽度的容器中

<Container>
    <Grid container spacing={2}>
        <Grid item sm={6}></Grid>
        <Grid item sm={6}></Grid>
        <Grid item sm={6}></Grid>
        <Grid item sm={6}></Grid>
   </Grid>
</Container>

通过这种方式,容器会处理溢出,并且网格总是响应性地扩展到父级中。这是迄今为止我发现的最优雅的解决方案。

提示:如果您使用此库来创建类似仪表板的内容,则始终将内容区域的父级设置为<Container>,这样就不会发生溢出问题。试一试。在挣扎了一段时间并且到处都只找到不优雅的解决方案后,对我来说效果很好。我必须说这应该在 react Material UI 页面中很好地记录下来。