0

我有这个类可以为不同的对话加载消息:

export class Messages extends Component {
  constructor() {
    super();
    this.state = {
      page: 0,
      results_per_page: 10,
      messages: [],
    };

    this.loadAnotherSetOfMessages = this.loadAnotherSetOfMessages.bind(this);
    this.checkIfUserHasPickedAnotherConversation =
      this.checkIfUserHasPickedAnotherConversation.bind(this);
  }

  componentDidMount() {
    // #NOTE
    // This will load first set of messages for first conversation opened by user
    this.loadAnotherSetOfMessages();
  }
  componentDidUpdate(prevProps, prevState) {
    this.checkIfUserHasPickedAnotherConversation(prevProps);
  }
  loadAnotherSetOfMessages() {
    const { page, results_per_page } = this.state;
    const conv_id = this.props.private_chat.current_chat._id;
    this.props.getXNumberOfMessages(conv_id, page, results_per_page);
    this.setState({
      page: this.state.page + 1,
    });
  }
  checkIfUserHasPickedAnotherConversation(prevProps) {
    const has_user_clicked_a_conversation =
      !!this.props.private_chat.current_chat;

    if (has_user_clicked_a_conversation) {
      const previous_conv_id = prevProps.private_chat.current_chat._id;

      const new_conv_id = this.props.private_chat.current_chat._id;

      const has_user_picked_another_conversation =
        previous_conv_id != new_conv_id;

      if (has_user_picked_another_conversation) {
        this.resetMessages();
        this.loadAnotherSetOfMessages();
      }
    }
  }

  resetMessages() {
    this.setState({
      page: 0,
      messages: [],
    });
  }
  // render() {}
}

每次用户单击新对话时,我都会使用此功能重置状态resetMessages

  if (has_user_picked_another_conversation) {
    this.resetMessages();
    // This function needs to get executed after the update inside resetMessages has happened
    this.loadAnotherSetOfMessages();
  }

这是它的定义:

  resetMessages() {
    this.setState({
      page: 0,
      messages: [],
    });
  }

这样当函数在它之后执行时,loadAnotherSetOfMessages它的定义如下:

  loadAnotherSetOfMessages() {
    const { page, results_per_page } = this.state;
    const conv_id = this.props.private_chat.current_chat._id;
    this.props.getXNumberOfMessages(conv_id, page, results_per_page);
    this.setState({
      page: this.state.page + 1,
    });
  }

使用带有 value和value的初始state参数,因为这是一个全新的对话。page0messages[]

我面临的问题loadAnotherSetOfMessages是该函数不是使用重新初始化的状态参数执行的0[]而是使用先前对话的最新值执行的。
例如,如果之前的对话已经加载到页面5,那么它将使用5而不是0.
我该怎么办?

4

1 回答 1

1

你不能使用 state,react 的原因setState是异步的,这意味着在 state 中设置一个新值后,你将不得不等待组件的下一次重新渲染来获取更新的 state 值。如果您在设置后立即尝试获取状态值,您将始终以之前的值结束。

所以最好的办法是,你将新的状态值作为参数传递给你的loadAnotherSetOfMessages函数并使用它。像

loadAnotherSetOfMessages(page, results_per_pag) {
    const conv_id = this.props.private_chat.current_chat._id;
    this.props.getXNumberOfMessages(conv_id, page, results_per_page);
    this.setState({
      page: page + 1,
    });
}

并称它为

this.loadAnotherSetOfMessages(page, results)
于 2022-01-02T13:12:35.957 回答