如何在 material UI 中设置值和选项 AutoComplete 和 onChange 将值分配给对象?
How to set value and option in material UI AutoComplete and onChange assign the value to a object?
我在页面加载类别上有一个带有字段 cat_id
的品牌对象
加载到自动完成 select。现在我想将 category id
设置为
自动完成中带有类别选项的值,并设置 cat_id
来自自动完成选项值 onChange
.
const handleChange = (e) => {
const { name, value } = e.target;
setBrand({
...brand,
[name]: value,
});
};
<Autocomplete
getOptionSelected={(option, value) => option.category_name === value.id}
getOptionLabel={(option) => option.category_name}
name="cat_id"
onInputChange={handleChange}
options={categories}
loading={loading}
renderInput={(params) => (
<TextField
{...params}
label="Category"
fullWidth
variant="outlined"
required
InputProps={{
...params.InputProps,
endAdornment: (
<Fragment>
{" "}
{loading ? <CircularProgress color="inherit" /> : null}{" "}
{params.InputProps.endAdornment}
</Fragment>
),
}}
/>
)}
/>;
稍等片刻后得到帮助。我设法解决了这个问题,但我不确定这是不是推荐的方法。我直接设置了字段值onChange
,并没有使用handleChange
函数
<Autocomplete
getOptionSelected={(option, value) => option.category_name === value.id}
getOptionLabel={(option) => option.category_name}
name="cat_id"
options={categories}
loading={loading}
onChange={(e,option) => setBrand({...brand,cat_id: option.id,})}
renderInput={(params) => (
<TextField
{...params}
label="Category"
fullWidth
variant="outlined"
required
InputProps={{
...params.InputProps,
endAdornment: (
<Fragment>
{" "}
{loading ? <CircularProgress color="inherit" /> : null}{" "}
{params.InputProps.endAdornment}
</Fragment>
),
}}
/>
)}
/>;
我在页面加载类别上有一个带有字段 cat_id
的品牌对象
加载到自动完成 select。现在我想将 category id
设置为
自动完成中带有类别选项的值,并设置 cat_id
来自自动完成选项值 onChange
.
const handleChange = (e) => {
const { name, value } = e.target;
setBrand({
...brand,
[name]: value,
});
};
<Autocomplete
getOptionSelected={(option, value) => option.category_name === value.id}
getOptionLabel={(option) => option.category_name}
name="cat_id"
onInputChange={handleChange}
options={categories}
loading={loading}
renderInput={(params) => (
<TextField
{...params}
label="Category"
fullWidth
variant="outlined"
required
InputProps={{
...params.InputProps,
endAdornment: (
<Fragment>
{" "}
{loading ? <CircularProgress color="inherit" /> : null}{" "}
{params.InputProps.endAdornment}
</Fragment>
),
}}
/>
)}
/>;
稍等片刻后得到帮助。我设法解决了这个问题,但我不确定这是不是推荐的方法。我直接设置了字段值onChange
,并没有使用handleChange
函数
<Autocomplete
getOptionSelected={(option, value) => option.category_name === value.id}
getOptionLabel={(option) => option.category_name}
name="cat_id"
options={categories}
loading={loading}
onChange={(e,option) => setBrand({...brand,cat_id: option.id,})}
renderInput={(params) => (
<TextField
{...params}
label="Category"
fullWidth
variant="outlined"
required
InputProps={{
...params.InputProps,
endAdornment: (
<Fragment>
{" "}
{loading ? <CircularProgress color="inherit" /> : null}{" "}
{params.InputProps.endAdornment}
</Fragment>
),
}}
/>
)}
/>;