Я реализовал раскрывающийся список множественного выбора из документации по реакционной-загрузке .
Это не позволяет мне сделать множественный выбор и получает только последний нажатый параметр. У меня есть переменная состояния для массива. Что еще мне не хватает? Приложение создается с помощью create-реагировать-приложение .
У меня установлено состояние для массива внутри конструктора класса. Привязка обработчика событий также выполняется в конструкторе.
Далее я показываю мой обработчик событий, за которым следует группа форм с onChange
и значением, установленным в состояние. (обратите внимание, что у меня есть выпадающий список, который работает нормально.)
Затем я передаю это значение нескольким классам, прежде чем оно будет проанализировано в JSON. Последние пасты - это те классы. Я удалил другие параметры, чтобы их было легче читать, любые идеи, не стесняйтесь спрашивать дополнительную информацию.
this.state = {
codeCoverage: [],
}
this.handleCodeCoverageChange = this.handleCodeCoverageChange.bind(this);
//Event handlers below
handleCodeCoverageChange(event){
this.setState({
codeCoverage: event.target.value
})
}
<Form.Group>
<Form.Label>Please choose your desired code coverage software(s)</Form.Label>
<Form.Control as="select" value={this.state.codeCoverage} onChange={this.handleCodeCoverageChange} multiple>
<option value="">--Please choose an option--</option>
<option value="cobertura">Cobertura</option>
<option value="sonarcube">Sonarcube</option>
</Form.Control>
</Form.Group>
var configurator = new Configurator(this.state.codeCoverage)
class Configurator
{
constructor(
code_coverage)
{
this.pipeline = new Pipeline(code_coverage)
}
}
class Pipeline
{
constructor(code_coverage)
{
this.analysisAndSecurity = new AnalysisAndSecurity(code_coverage)
}
class AnalysisAndSecurity{
parameter
constructor(code_coverage)
{
this.code_coverage = code_coverage
}
}