Ral*_*thy 5 javascript html-select reactjs
所以我有一个下拉组件:
import React from 'react';
import { PropTypes } from 'prop-types';
export default class Dropdown extends React.Component {
constructor(props) {
super(props);
this.state = {
value: this.props.selectedDropdownValue,
};
this.handleChange = this.handleChange.bind(this);
}
handleChange(e) {
this.setState({
value: e.target.value,
});
this.props.onChange(e.target.value);
}
render() {
let disabled = false;
let dropdownOptions = null;
const { options } = this.props;
// Disable dropdown is the disabled attribute is added
if (options) {
dropdownOptions = this.props.options.map((option) =>
<option value={option.key} key={option.key} >{option.display}</option>,
);
} else {
// Setting default options
const defaultOptions = [
{ key: '', display: 'Please configure defaultOptions' },
];
disabled = true;
dropdownOptions = defaultOptions.map((option) =>
<option value={option.key} key={option.key} >{option.display}</option>,
);
}
return (
<select
value={this.state.value}
onChange={this.handleChange}
disabled={disabled}
>
{ dropdownOptions }
</select>
);
}
}
Dropdown.propTypes = {
options: PropTypes.arrayOf(PropTypes.object),
onChange: PropTypes.func,
selectedDropdownValue: PropTypes.string,
};
Dropdown.defaultProps = {
options: undefined,
onChange: this.handleChange,
selectedDropdownValue: '',
};
Run Code Online (Sandbox Code Playgroud)
这是我在视图中呈现下拉列表的方式:
import React from 'react';
import { PropTypes } from 'prop-types';
import Dropdown from 'components/Dropdown';
class Anish extends React.Component {
render() {
return (
<div>
<div>
Value Selected: {this.props.selectedDropdownValue}
</div>
<label htmlFor={'dropdownId1'}>Sort by: </label>
<Dropdown
id="dropdownId1"
options={[
{ key: '', display: 'Please select a value' },
{ key: 'NJ', display: 'New Jersey' },
{ key: 'NY', display: 'New York' },
]}
onChange={this.props.onSetDropdownValue}
/>
</div>
);
}
}
Anish.propTypes = {
selectedDropdownValue: PropTypes.string,
onSetDropdownValue: PropTypes.func.isRequired,
};
Anish.defaultProps = {
selectedDropdownValue: '',
};
export default Anish;
Run Code Online (Sandbox Code Playgroud)
以下是下拉列表和标签在浏览器中的呈现方式:
那么如何将其上的 id 应用<Dropdown />到<select>它的内部呢?
任何帮助表示赞赏。
props将包含组件的 ID Dropdown,但由于您位于 React 组件中,所以使用this.props.
return (
<select
id={this.props.id}
value={this.state.value}
onChange={this.handleChange}
disabled={disabled}
>
{dropdownOptions}
</select>
)
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
28575 次 |
| 最近记录: |