如果您不想使用 Autocomplete 组件来渲染元素,您可以使用其他方式来实现同样的效果。下面是一个使用 React 和 Material-UI 的示例代码来展示这种解决方法:
import React, { useState } from "react";
import TextField from "@mui/material/TextField";
import MenuItem from "@mui/material/MenuItem";
const options = ["Option 1", "Option 2", "Option 3"];
export default function MyAutocomplete() {
const [value, setValue] = useState("");
const [open, setOpen] = useState(false);
const handleChange = (event) => {
setValue(event.target.value);
};
const handleOpen = () => {
setOpen(true);
};
const handleClose = () => {
setOpen(false);
};
return (
{open && (
{options
.filter((option) =>
option.toLowerCase().includes(value.toLowerCase())
)
.map((option) => (
))}
)}
);
}
在这个例子中,我们使用了一个
组件来实现输入框的功能,并使用 value
和 onChange
属性来跟踪输入值的变化。当输入框获得焦点时,我们打开了一个下拉菜单,并根据输入值过滤出匹配的选项进行渲染。当用户选择了一个选项后,我们更新输入框的值并关闭下拉菜单。
请注意,这个示例只是展示了一种不使用 Autocomplete 组件来实现类似功能的方法,并不具有完整的自动完成功能(如键盘导航、自动完成等)。如果您需要更高级的自动完成功能,建议使用 Material-UI 的 Autocomplete 组件。