win*_*ter 5 javascript typescript reactjs material-ui
我正在使用 Material UI Select 组件,我正在尝试在内部构建一个过滤器,以仅显示与用户输入的输入相匹配的项目。
我构建了一个我正在开发的最小示例。
function App() {
const [selectedOption, setSelectedOption] = React.useState("");
const [filterExpression, setFilterExpression] = React.useState("");
const onChangeSelection = (
event: React.ChangeEvent<{ name?: string | undefined; value: unknown }>,
child: React.ReactNode
) => {
const value = event.target.value.toString();
setSelectedOption(value);
};
const onChangeExpression = (
event: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>
) => {
const value = event.target.value.toString();
console.log(`value:`, value);
setFilterExpression(value);
};
const stopImmediatePropagation = (e: any) => {
e.stopPropagation();
e.preventDefault();
};
return (
<div className="App">
<Select onChange={onChangeSelection} value={selectedOption}>
<MenuItem
dense
divider
value={""}
onClickCapture={stopImmediatePropagation}
>
<TextField value={filterExpression} onChange={onChangeExpression} />
</MenuItem>
<MenuItem dense key={"One"} value={"One"}>
One
</MenuItem>
<MenuItem dense key={"Two"} value={"Two"}>
Two
</MenuItem>
<MenuItem dense key={"Three"} value={"Three"}>
Three
</MenuItem>
</Select>
</div>
);
}
Run Code Online (Sandbox Code Playgroud)
我现在的问题是,默认情况下,选择组件允许用户按下任何字母,如果有第一个字母与用户输入匹配的选项,它会选择该选项。
因此,如果我有 3 个选项(One
,Two
和Three
)并且用户键入O
选择组件将选择该One
选项并且我的文本字段的值不会改变。但是,如果用户键入,F
则文本字段将更新为F
。
我想禁用此行为,因此,我一直在尝试阻止诸如onKeyUpCapture
,之类的事件的传播onChangeCapture
,onKeyDownCapture
但我无法避免这种情况。
你有什么建议来解决它吗?您可以在此处查看功能示例:
Rya*_*ell 14
文本焦点导航功能在实现onKeyDown
的MenuList
(我实现它前6个月左右)。停止在 上传播该事件MenuItem
(它也可以在 上停止传播TextField
)可防止事件到达MenuList
。
import * as React from "react";
import { render } from "react-dom";
import TextField from "@material-ui/core/TextField";
import Select from "@material-ui/core/Select";
import MenuItem from "@material-ui/core/MenuItem";
import "./styles.css";
function App() {
const [selectedOption, setSelectedOption] = React.useState("");
const [filterExpression, setFilterExpression] = React.useState("");
const onChangeSelection = (
event: React.ChangeEvent<{ name?: string | undefined; value: unknown }>,
child: React.ReactNode
) => {
const value = event.target.value.toString();
setSelectedOption(value);
};
const onChangeExpression = (
event: React.ChangeEvent<HTMLInputElement | HTMLTextAreaElement>
) => {
const value = event.target.value.toString();
console.log(`value:`, value);
setFilterExpression(value);
};
const stopImmediatePropagation = (e: any) => {
e.stopPropagation();
e.preventDefault();
};
return (
<div className="App">
<Select onChange={onChangeSelection} value={selectedOption}>
<MenuItem
dense
divider
value={""}
onClickCapture={stopImmediatePropagation}
onKeyDown={e => e.stopPropagation()}
>
<TextField value={filterExpression} onChange={onChangeExpression} />
</MenuItem>
<MenuItem dense key={"One"} value={"One"}>
One
</MenuItem>
<MenuItem dense key={"Two"} value={"Two"}>
Two
</MenuItem>
<MenuItem dense key={"Three"} value={"Three"}>
Three
</MenuItem>
</Select>
</div>
);
}
const rootElement = document.getElementById("root");
render(<App />, rootElement);
Run Code Online (Sandbox Code Playgroud)
归档时间: |
|
查看次数: |
2841 次 |
最近记录: |