如何将多个参数传递给输入的onChange处理程序

Pio*_*rak 45 javascript reactjs

我为数组中的对象渲染输入元素的集合.

render: function() {
    var ranges = [];
    this.props.ranges.map(function(range, index) {
        var rangeElement = <Input type="text"
            value={range.name} onChange={this.changeRangeName.bind(this)} />
        ranges.push(rangeElement);
    }, this);

    // render ranges
}
Run Code Online (Sandbox Code Playgroud)

这允许我写onChange处理函数:

changeRangeName: function (event) {
    var newName = event.target.value;
},
Run Code Online (Sandbox Code Playgroud)

但在这个处理程序中,我需要我想改变的范围对象的id.所以我可以改变更改如何在渲染函数中创建输入元素并更改:

var rangeElement = <Input type="text"
            value={range.name}
            onChange={this.changeRangeName.bind(this, range.id)} />
Run Code Online (Sandbox Code Playgroud)

现在我的处理程序将接收range.id作为参数,但现在我没有newName值.我可以使用refs来获取它

var rangeElement = <Input type="text"
            ref={'range' + range.id}
            value={range.name}
            onChange={this.changeRangeName.bind(this, range.id)} />
Run Code Online (Sandbox Code Playgroud)

这是我所知道的唯一解决方案,但我怀疑有更好的解决方案.

Ego*_*tov 73

我认为这种方式更容易:

    <Input type="text"
                value={range.name}
                onChange={(e) => this.changeRangeName(range.id, e)}
        ...
    onChange(id, e) {
        ...
    }
Run Code Online (Sandbox Code Playgroud)

  • 缺点:每次渲染时都会创建一个新的匿名函数实例,这可能是一个性能缺陷.你怎么看? (6认同)

Ale*_*erg 41

event参数还通过了,但rangeId参数前置到参数列表,让你的changeRangeName方法看起来像

changeRangeName: function (rangeId, event) {
    var newName = event.target.value;
},
Run Code Online (Sandbox Code Playgroud)

请参见Function.prototype.bind()