javascript - React - 当 Prop 通过父状态更新时,子组件不会更新

标签 javascript reactjs react-native ecmascript-6

我有一个 react native 组件 -

export default class Chat extends Component {
  constructor(props) {
    super(props);

    this.state = {
      behavior: 'padding',
      text: '',
      messages: this.props.chat.messages
    };
  }

  updateText() {
    this.setState({
      messages: this.state.messages.concat( { message: this.state.text } )
    })
  }

  render() {
    return (

      <KeyboardAvoidingView behavior={this.state.behavior} style={styles.container}>
        <View style={styles.chatContainer}>
          <MessageList messages={this.state.messages} />
        </View>
        <View style={styles.textContainer}>
          <BorderedTextInput
            placeholder="Type something..."
            onSubmitEditing={ this.updateText.bind(this) }
            onChangeText={(text) => this.setState({text})}
            value={this.state.text}
            style={styles.textInput} />
          <IconBar />
        </View>
      </KeyboardAvoidingView>

    );
  }
}

它的状态有消息数组,当使用文本输入时该数组会更新。这被传递到 MessageList 组件。

export default class MessageList extends Component {
  constructor(props) {
    super(props);
    const ds = new ListView.DataSource({rowHasChanged: (r1, r2) => r1 !== r2});
    this.state = {
      dataSource: ds.cloneWithRows(this.props.messages),
    };
  }

  _renderRow(chat){
    return (
      <FadeInListRow>
        <View style={this._bubbleContainerStyle(chat)}>
          <Text style={this._bubbleStyles(chat)}>{chat.message}</Text>
        </View>
      </FadeInListRow>
    )
  }

  render() {
    return (
      <View style={styles.container}>
        <View style={styles.timeContainer}>
          <Text style={styles.timeText}>
            Mon, Jun 2, 22:09
          </Text>
        </View>

        <ListView
          dataSource={this.state.dataSource}
          renderRow={this._renderRow.bind(this)}
          contentContainerStyle={styles.listView}
           style={{flex: 1, paddingTop: 50}}
        />
      </View>
    )
  }
}

我预计 _renderRow 会再次被调用,并且我的 ListView 会在父状态更新时更新。它不是。知道我做错了什么吗?

最佳答案

当前代码看起来不错。我建议两件事:

  1. 确认state中的message属性确实已更新onSubmit()。您可以在 chat 类的 return 命令之前记录它。

  2. 确认 MessageList 组件上 props 中的 message 属性与父级更新的周期相同。

我这么说有一个前提:状态更新的大多数问题通常是由于数据更新不一致造成的。如果数据没有改变,组件就不会被重新渲染。

关于javascript - React - 当 Prop 通过父状态更新时,子组件不会更新,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39029102/

相关文章:

reactjs - ReactJs 的异常处理和错误记录限制

react-native - FontFamily "Material Design Icons"不是系统字体,尚未通过 Font.loadAsync 加载

javascript - Scrollspy 导航栏 fullPage.js

javascript - 使用数组中的多个选择器查询 DOM

javascript - React中有三元运算符数据时传入<li>

react-native - 如何在 Windows 上运行 React Native 排毒?

android - TextInput - Samsung Pass 提示未出现

javascript - 如何在我的 HTML 输入文本中添加默认文本

javascript - ClickAwayListener 在嵌套组件中禁用 onClick

javascript - 为什么这个 Promise 中的 setState 比异步函数的相同代码需要更长的时间来更新?