Ho un componente ReactJS
:Perché non fa questo elenco di selezione rendering con l'articolo corretto selezionato in base alla defaultValue
var RegionsList = React.createClass({
handleChange: function() {
var regionId = this.refs.userRegions.getDOMNode().value;
this.props.onRegionSelected(regionId);
},
componentDidMount: function() {
$.get("/translation/activeuserregions", function(result) {
if(this.isMounted()) {
this.setState({
selectedRegionId: result.SelectedRegionId,
regions: result.Regions
})
}
}.bind(this));
},
getInitialState: function(props) {
return {
selectedRegionId: '',
regions: []
}
},
render: function() {
return (
<div id="RegionsListForm" className="navbar-form navbar-left regions-list">
<div className="input-group navbar-searchbox">
<span className="input-group-addon">
<span>Region</span>
</span>
<select ref="userRegions" onChange={this.handleChange} defaultValue={this.state.selectedRegionId} className="form-control valid" id="region" name="region" aria-invalid="false">
{this.state.regions.map(function(region) {
return <option key={region.Id} value={region.Id} label={region.RegionName}>{region.RegionName}</option>
})}
</select>
</div>
</div>
);
},
})
E sembra funzionare correttamente. Ma inizialmente non esegue il rendering con l'elemento corretto selezionato. Sebbene il defaultValue
sembra essere impostato correttamente, quindi non capisco perché.
Cosa sto sbagliando?
Grazie Ben, ha funzionato come un fascino –