【发布时间】:2020-02-11 04:43:36
【问题描述】:
我正在使用材质 UI 选择组件,我正在尝试在内部构建一个过滤器以仅显示与用户输入的输入匹配的项目。
我构建了一个我正在开发的最小示例。
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>
);
}
我现在的问题是,默认情况下,选择组件允许用户按任何字母,如果有第一个字母与用户输入匹配的选项,它会选择该选项。
所以,如果我有 3 个选项(One、Two 和 Three)并且用户键入 O,则选择组件将选择 One 选项,而我的文本字段的值不会改变。但是,如果用户键入F,则文本字段将更新为F。
我想禁用此行为,因此,我一直在尝试阻止 onKeyUpCapture、onChangeCapture、onKeyDownCapture 等事件的传播,但我无法避免这种情况。
您有什么建议可以解决吗? 您可以在此处查看功能示例:
【问题讨论】:
标签: javascript reactjs typescript material-ui