我想知道如何使用React中的input[type="range"]
获得数组中索引的值,类似于this example?React JS范围滑块 - 使用数组作为值?
我想要做的是这样的:传递一个值的范围,并能够通过使用数组的索引打印出这些值。你可以从下面的示例代码中看到,我最初呈现的是我想要的值(在本例中为'Apples'),但是当我使用幻灯片时,它开始呈现数组的索引,而不是的价值。
这里是我到目前为止有:
class RangeSlider extends React.Component {
// constructor
constructor(props) {
super(props);
this.state = {
value: props.value[0]
};
}
handleChange(event, index) {
const { value } = this.state;
this.setState({ value: event.target.value});
}
render() {
const { value } = this.state;
const { label } = this.props;
return (
<div className="mb4">
<label className="f4 mt0">
{label} <b className="fw7 pl1">{value}</b>
</label>
<input
className="w-100 appearance-none bg-transparent range-slider-thumb-custom"
type="range"
min={0}
max={this.props.value.length - 1}
step={1}
value={value}
onChange={this.handleChange.bind(this)}
/>
</div>
);
}
}
window.onload =() => {
ReactDOM.render(
<RangeSlider
label={"I would like some "}
value={["Apples", "Oranges", "Pears"]} />,
document.getElementById("main"));
};
链接a Codepen。
你的意思是这样https://codepen.io/maio/pen/qXMVda? – maioman
@maioman就是这样,谢谢! – A7DC