доступ к состоянию внутри Calculateate из componentdidmount - PullRequest
1 голос
/ 29 мая 2020

Я новичок в потоке и реагировании, и я хотел бы знать, как я могу получить доступ к состоянию внутри Calculatestate () из componentdidmount ()? Я хотел бы l oop через события, а затем выполнить запрос для каждого события, который, в свою очередь, обновляет другое хранилище.

static getStores() {
  return [SomeStore];
}
static calculateState(prevState, props) {
  const somestore = SomeStore.getState();

  return {
    events: SomeStore.getState(),
  };
}

componentdidmount(){

  //this.state.events;
  //need to do some query based on the events
  //this query will update another store.
}

1 Ответ

0 голосов
/ 29 мая 2020

Вам необходимо использовать методы жизненного цикла, чтобы понять метод componentDidMount, который описан здесь

Для инициализации локального состояния вы должны использовать метод конструктора (stati c can также может использоваться в качестве альтернативы, но jsfiddle выдает ошибку.

Чтобы показать начальное состояние, вы можете войти в componentDidMount с помощью this.state.

const someStore = ["event"];

class TodoApp extends React.Component {
  constructor(props) {
    super(props);
    this.state = { events: someStore };
  }

  // if you want to change state based on props
  shouldComponentUpdate(nextProps, nextState) {
    // change state if you want here
    if (this.state.events.length !== nextState.events.length) {
      console.log(this.state, nextState)
      return true // update
    }

    return false
  }

  // get initial state
  componentDidMount() {
    console.log(this.state.events);
  }

  render() {
    return (
      <div>
        <span>example</span>
        <button onClick = {() => {
          this.setState(state => {
            return {
              events: [...state.events, "new event"]
            }
          })
        }}>Add Event</button>
        
        <div>
          events: { JSON.stringify(this.state.events) }
        </div>
      </div>
    )
  }
}

ReactDOM.render(<TodoApp />, document.querySelector("#app"));
body {
  background: #20262E;
  padding: 20px;
  font-family: Helvetica;
}

#app {
  background: #fff;
  border-radius: 4px;
  padding: 20px;
  transition: all 0.2s;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/react/16.6.3/umd/react.production.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/react-dom/16.6.3/umd/react-dom.production.min.js"></script>
<div id="app"></div>
...