我多次尝试过文档中给出的示例。但它对我来说效果不佳。 谁能帮我.... 这是代码
import React, {Component} from 'react';
import SelectField from 'material-ui/SelectField';
import MenuItem from 'material-ui/MenuItem';
const names = [
'Oliver Hansen',
'Van Henry',
'April Tucker',
'Ralph Hubbard',
'Omar Alexander',
'Carlos Abbott',
'Miriam Wagner',
'Bradley Wilkerson',
'Virginia Andrews',
'Kelly Snyder',
];
/**
* `SelectField` can handle multiple selections. It is enabled with the `multiple` property.
*/
export default class SelectFieldExampleMultiSelect extends Component {
state = {
values: [],
};
handleChange = (event, index, values) => this.setState({values});
menuItems(values) {
return names.map((name) => (
<MenuItem
key={name}
insetChildren={true}
checked={values && values.indexOf(name) > -1}
value={name}
primaryText={name}
/>
));
}
render() {
const {values} = this.state;
return (
<SelectField
multiple={true}
hintText="Select a name"
value={values}
onChange={this.handleChange}
>
{this.menuItems(values)}
</SelectField>
);
}
}
http://www.material-ui.com/#/components/select-field
select属性有效,但它不会选择多个选项。当我检查states.value时,它只包含一个值而不是一个值数组
答案 0 :(得分:3)
这个例子也不适用于我。要添加多选功能,您必须手动将新值添加到状态,因此示例中的handleChange函数将如下所示:
handleChange(event, index, values) {
this.setState({
values: [...this.state.values , values]
});
}
编辑:我将我的材料版本ui更新为最新的稳定版本,他们的示例就像魅力一样
答案 1 :(得分:0)
一种更好的方法是可能的。在 Material UI 的最新版本中。
import Select from '@material-ui/core/Select';
import MenuText from '@material-ui/core/MenuText';
import {useState} from 'react';
const App = () => {
const [selected,setSelected] = useState([]);
return <Select multiple={true} value={selected} onChange={() => setSelected(e.target.value)}>
<MenuItem>Val - 1</MenuItem>
<MenuItem>Val - 2</MenuItem>
<MenuItem>Val - 3</MenuItem>
<MenuItem>Val - 4</MenuItem>
</Select>
}
确保将 select 的值设置为数组。否则,它将不起作用