微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

禁用键盘句柄 AppBar TabPanel MUI

如何解决禁用键盘句柄 AppBar TabPanel MUI

我有一个带有 AppBar/TabPanel 的 Menu 和带有 Textfield 的 MenuItem :

<Menu
                anchorEl={anchorEl}
                anchorOrigin={{ vertical: 'top',horizontal: 'right' }}
                id={menuId}
                keepMounted
                transformOrigin={{ vertical: 'top',horizontal: 'right' }}
                open={isMenuOpen}
                onClose={handleMenuClose}
                style={{zIndex: 1401,marginTop: "55px"}}
                className={classes.renderMenu}
                elevation={5}
              >
                <AppBar position="static" style={{ marginTop: '-10px' }}>
                  <Tabs value={value} onChange={handleChange} aria-label="simple tabs example">
                    <Tab label="Connexion" {...a11yProps(0)} />
                    <Tab label="Inscription" {...a11yProps(1)} />
                  </Tabs>
                </AppBar>

                <TabPanel value={value} index={0}>
                <form className={classes.container} onSubmit={handleLoginSubmit} >
                  <MenuItem  > 
                    <TextField
                      error={Boolean(emailLoginError)}
                      helperText={Boolean(emailLoginError) ? emailLoginError : ''}
                      className={classes.marginForm}
                      onChange={handleChangeEmailLogin}
                      id="email-login-id-2"
                      label="Email"
                      type="email"
                      InputLabelProps={{
                        classes: {
                          root: classes.label,focused: classes.focusedLabel,error: classes.erroredLabel
                        },}}
                      
                      InputProps={{
                        startAdornment: (
                          <InputAdornment position="start">
                            <AccountCircle />
                          </InputAdornment>
                        ),}}
                    />
                  </MenuItem>

......

问题是,如果我在文本字段中按 C 键,它会触发 TabPanel 并从文本字段中删除光标...当您要填写表单时非常烦人。

它以蓝色突出显示 TabPanel 导航,如您在图片上所见

TabPanel blue highlight after C keyboard press

我的目标是避免这种姿态​​。我试图捕获 TabPanel、Textfield 和 Menu 上的 C 键按下,但没有成功...

onKeyPress={ (e) => {
                        if (e.key === 'c') {
                          console.log('Enter key pressed');
                          // write your functionality here
                        }
                }}

帮助将不胜感激

Normal menu

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其他元素将获得点击?
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。)
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbcDriver发生异常。为什么?
这是用Java进行XML解析的最佳库。
Java的PriorityQueue的内置迭代器不会以任何特定顺序遍历数据结构。为什么?
如何在Java中聆听按键时移动图像。
Java“Program to an interface”。这是什么意思?