我正在尝试编写代码以在键盘输入时异步搜索多选组合。
然而我在最新版本(5.2.2)中发现了一个我无法解释的奇怪行为。我提炼出以下问题(基于 MUI 自动完成页面的示例):
import * as React from "react";
import TextField from "@mui/material/TextField";
import Autocomplete from "@mui/material/Autocomplete";
const options = [
{ label: "Option 1", value: 1 },
{ label: "Option 2", value: 2 }
];
export default function ControllableStates() {
// const [value, setValue] = React.useState<any | null>([]);
const value = [];
const [inputValue, setInputValue] = React.useState("");
console.log("Current Value:", value);
return (
<div>
<div>{`value: ${value !== null ? `'${value}'` : "null"}`}</div>
<div>{`inputValue: '${inputValue}'`}</div>
<br />
<Autocomplete
multiple={true}
value={value}
onChange={(event: any, newValue: any | null) => {
//setValue(newValue);
}}
inputValue={inputValue}
onInputChange={(event, newInputValue) => {
setInputValue(newInputValue);
}}
id="controllable-states-demo"
options={options}
sx={{ width: 300 }}
renderInput={(params) => <TextField {...params} label="Controllable" />}
/>
</div>
);
}
沙盒代码如下:https://codesandbox.io/s/controllablestates-material-demo-forked-ygqp2?file=/demo.tsx https://codesandbox.io/s/controllablestates-material-demo-forked-ygqp2?file=/demo.tsx
如果您在 codeSandbox 中尝试,您将无法在 TextField 字段中输入任何内容。
但是,如果您切换评论:
const [value, setValue] = React.useState<any | null>([]);
// const value = [];
您将能够在文本字段字段中输入内容。这里到底发生了什么?值根本没有改变。
谁能弄清楚为什么我的第一个代码(其中值是 const 空数组)不起作用?
我问的原因是我需要将(受控)值作为 props 传递,然后将其设置为默认值 [] (如果它为 null)。我发现由于这种默认设置,我无法在文本字段中输入内容。