首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >映射React Native时更新输入值

映射React Native时更新输入值
EN

Stack Overflow用户
提问于 2018-02-02 15:54:08
回答 3查看 864关注 0票数 2

我正在创建react-native mobile应用程序。我有一个带有一些值的数组。我想在输入字段中设置数组的值。我已经在字段中添加了值,但我无法更新这些值。我在一个qty变量中设置了如下值:

代码语言:javascript
运行
复制
constructor(props) {
  super(props);
  this.state = {
    qty:[],
  }
}

componentWillMount() {
  var ids = [];
  this.props.data.map((dataImage,Index) => {
    dataImage['pro-name'] != undefined && (
      ids.push({'qty':dataImage['pro-qty']})    
    )
  })

  this.setState({qty:ids})
}

render() {
  return {
    this.props.data.map((dataImage,Index)=>(
      <View key={Index} style={productStyle.cartview}>
        {dataImage['pro-name'] && (
          <View style={productStyle.cartmain}>
            <Input value={this.state.qty[Index]['qty']} onChange={this.handleChangeInput.bind(this)} style={{width:40,height:40,textAlign:'left'}} />
          </View>
        )}
      </View>
    ))
  }
}

它正确地将值显示在输入字段中,但我无法在字段中键入任何内容来更新值。我能为此做些什么?

EN

回答 3

Stack Overflow用户

发布于 2018-02-02 16:20:54

我建议您将输入容器移到单独的类中,这样更好,每个组件都会处理自己的状态。它易于处理,也会带来更好的性能。

代码语言:javascript
运行
复制
components = []

render() {
  return this.props.data.map((item, index) => (
    <CustomComponent data={item} index={index} ref={(ref) => this.components[index] = ref} />
  ))
}

然后,您可以从它的ref中获取子级(CustomComponent)值。

代码语言:javascript
运行
复制
this.components[index].getValue()
this.components[index].setValue('Value');

您需要在CustomComponent类中创建这些函数(getValuesetValue)。

解决方案

以下是对您查询的解决方案。您需要安装lodash或寻找其他解决方案来制作新的副本qty

代码语言:javascript
运行
复制
<Input onChangeText={(text) => this.handleChangeText(text, index)} />

handleChangeText = (text, index) => {
  const qty = _.cloneDeep(this.state.qty);
  qty[index] = {
    qty: text
  }
  this.setState({qty})
}
票数 2
EN

Stack Overflow用户

发布于 2018-02-02 18:15:47

您的输入值被设置为this.state.qty[Index]['qty']。要在文本编辑中更改它,您可以这样做。您不需要绑定函数,而是使用箭头函数,如下所示。

代码语言:javascript
运行
复制
onChangeText={ (newValue) => {
    this.setState({ <your-input-value-state>:newValue })
}}
票数 0
EN

Stack Overflow用户

发布于 2018-02-02 19:17:57

您必须在onChange事件上分别更新每个Input的值。

将您的替换为以下Input

代码语言:javascript
运行
复制
<Input value={this.state.qty[Index]['qty']}
       onChange={this.handleChangeInput.bind(this, Index)}
       style={{width:40,height:40,textAlign:'left'}}
/>

并在调用event时使用Index相应地更新状态

代码语言:javascript
运行
复制
handleChangeInput(index, value){
    let {qty} = this.state;
    let qty_update = qty.slice();
    qty_update[index]['qty']  = value;
    this.setState({qty: qty_update});
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/48578127

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档