[英]how to make a height responsive textfield in Material UI?
我需要制作一个具有响应高度的文本字段,因此当浏览器最小化/最大化时,高度将始终调整为父网格的大小。
我查找了一个解决方案,我只发现了这个: Responsive MaterialUI TextField?
它只给了我一个关于如何解决与宽度相同的问题的想法。 它不适用于高度。
这是我的代码:
const useStyles = makeStyles({
infogrid: {
width: '30%',
height: '39%',
display: 'inline-block',
position: 'absolute',
right: '8%',
top: '10%',
backgroundColor: '#00ffff',
borderRadius: '5vh',
alignItems: 'center',
justifyContent: 'center',
justifyItems: 'center',
flexDirection: 'column',
overflow: 'auto'
},
label: {
margin: '25%',
marginTop: '0.3%',
marginBottom: '0.3%',
display: 'block',
height: '9%',
width: '50%',
}
})
export default function App() {
const classes = useStyles()
<Grid className={classes.infogrid}>
<TextField fullWidth className={classes.label} id="ovalID" label="1" variant="outlined" />
<TextField fullWidth className={classes.label} id="latitude" label="2" variant="outlined" />
<TextField fullWidth className={classes.label} id="longitude" label="3" variant="outlined" />
<TextField fullWidth className={classes.label} id="ovalRadius1" label="4" variant="outlined" />
<TextField fullWidth className={classes.label} id="ovalRadius2" label="5" variant="outlined" />
<TextField fullWidth className={classes.label} id="angel" label="6" variant="outlined" />
</Grid>
);
}
只需使用<Stack>
组件将所有内容包装在<Grid>
中。
<Grid>
<Stack>
<TextField />
<TextField />
<TextField />
<TextField />
</Stack>
</Grid>
应该使您的TextField
高度在网格项目中响应。
我只是通过将父网格更改为 div 并将 div 的显示设置更改为“flex”来解决它。 此外,我将“标签”class 中的 marginTop 和 marginBottom 设置设置得更高一点。
只要父 div 将 flex 方向设置为“列”。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.