我正试图找出一种更简洁的方法来使用箭头键在使用React的输入列表中上下移动焦点。列表是父组件,输入子组件。为了弄清楚下一步应该关注哪些输入,我给每个孩子一个ref
以及我用来跟踪排序的数字id
。当检测到箭头键时,回调然后找到具有正确ref
的孩子并进入该孩子的refs
以获取输入并给予焦点。
我是React的新手,感觉很脏,所以我想知道是否有更清洁的解决方案。
代码和工作jsfiddle:
var Child = React.createClass({
handleUp: function(e) {
switch(e.key) {
case "ArrowDown":
this.props.handleFocus(this.props.id+1);
break;
case "ArrowUp":
this.props.handleFocus(this.props.id-1);
break;
}
},
render: function() {
return <div><input defaultValue={this.props.name} onKeyUp={this.handleUp} ref="input" /></div>;
}
});
var Parent = React.createClass({
handleFocus: function(id) {
var child = this.refs['child' + id];
if (!child) return;
var input = child.refs.input;
input.getDOMNode().focus();
},
render: function() {
var inputs = [];
for (var i=0; i<10; i++) {
inputs.push(<Child key={i} id={i} name={"value" + i} handleFocus={this.handleFocus} ref={'child' + i} />);
}
return <div>
{inputs}
</div>;
}
});
答案 0 :(得分:3)
有几种方法可以做到这一点,但没有一种方法比这更好。
替代方案将使用mixin,但这会带来黑盒抽象的心理成本,而收益微乎其微。我只是保持原样。