为什么对象道具不显示在平面列表中?

时间:2019-10-22 13:47:50

标签: react-native react-native-flatlist listitem

    this.state={

      task : "",
      the_array : []


    };
  }

  handleTextChange=(some_task) =>{

    this.setState({
      task : some_task

    });
  }

  pushToList = () => {
    let taskitem = {
      name: this.state.task,
    };
    this.setState({
      the_array: [...this.state.the_array, taskitem],
    });
  }

  render() {
    return(
      <View style={{backgroundColor:'powderblue', height:'100%'}}>
        <FlatList data = {this.state.the_array}
          renderItem={(item) => <Text>{item.name}</Text>} keyExtractor={(item) => item.name} >
        </FlatList>        
        <TextInput style={{ backgroundColor: 'lightsteelblue', height:60, borderRadius : 25, marginBottom:20}} 
        onChangeText={this.handleTextChange}>
        </TextInput>

        <TouchableOpacity style={{
          backgroundColor: 'mediumpurple', height: 60, width: 80, alignSelf: 'center', borderRadius: 20, justifyContent: 'center',
          alignItems: 'center', marginBottom:20
        }} onPress={this.pushToList}>

这是我的代码。我正在尝试将Textinput内容添加到Flatlist。为此,我在按钮onPress方法('pushToList')内定义了一个名为“ taskitem”的对象,并为其设置了一个名为“ name”的道具。 'pushTolistMethod'应该将'name'放入屏幕上的Flatlist。但是奇怪的是它不起作用,当我按下按钮时什么也没发生。我想知道是否有人可以帮助我。

1 个答案:

答案 0 :(得分:1)

您可以像这样替换您的清单代码并尝试吗?

    <FlatList data = {this.state.the_array}
      renderItem={({ item }) => <Text>{item.name}</Text>} keyExtractor={(item) => item.name} >
    </FlatList>  

数据在项目键上,因此我们使用解构从函数内部访问数据。