Похоже, что componentWillReceiveProps будет полностью прекращен в следующих выпусках в пользу нового метода жизненного цикла getDerivedStateFromProps:static getDerivedStateFromProps ().

После проверки похоже, что теперь вы не можете провести прямое сравнение между this.props и nextProps, как вы можете в componentWillReceiveProps. Есть ли способ обойти это?

Кроме того, теперь он возвращает объект. Правильно ли я предполагаю, что возвращаемое значение по существу this.setState?

Ниже приведен пример, который я нашел в Интернете: Состояние, полученное из props / state.

До

class ExampleComponent extends React.Component {
  state = {
    derivedData: computeDerivedState(this.props)
  };

  componentWillReceiveProps(nextProps) {
    if (this.props.someValue !== nextProps.someValue) {
      this.setState({
        derivedData: computeDerivedState(nextProps)
      });
    }
  }
}

После

class ExampleComponent extends React.Component {
  // Initialize state in constructor,
  // Or with a property initializer.
  state = {};

  static getDerivedStateFromProps(nextProps, prevState) {
    if (prevState.someMirroredValue !== nextProps.someValue) {
      return {
        derivedData: computeDerivedState(nextProps),
        someMirroredValue: nextProps.someValue
      };
    }

    // Return null to indicate no change to state.
    return null;
  }
}

Andrew

Ответы (4)

Об удалении componentWillReceiveProps: вы должны иметь возможность обрабатывать его использование с помощью комбинации getDerivedStateFromProps и componentDidUpdate, см. в блоге React post например миграции. И да, объект, возвращаемый getDerivedStateFromProps, обновляет состояние аналогично объекту, переданному в setState.

Если вам действительно нужно старое значение свойства, вы всегда можете кэшировать его в своем состоянии примерно так:

state = {
  cachedSomeProp: null
  // ... rest of initial state
};

static getDerivedStateFromProps(nextProps, prevState) {
  // do things with nextProps.someProp and prevState.cachedSomeProp
  return {
    cachedSomeProp: nextProps.someProp,
    // ... other derived state properties
  };
}

Все, что не влияет на состояние, можно поместить в componentDidUpdate, и есть даже getSnapshotBeforeUpdate для очень низкоуровневых вещей.

ОБНОВЛЕНИЕ: Чтобы получить представление о новых (и старых) методах жизненного цикла, может оказаться полезным пакет react-lifecycle-visualizer.

По словам Дана Абрамова

Сделать прямо внутри рендера

На самом деле мы используем этот подход с memoise one для любого типа проксирования свойств для констатирования вычислений.

Наш код выглядит так

// ./decorators/memoized.js  
import memoizeOne from 'memoize-one';

export function memoized(target, key, descriptor) {
  descriptor.value = memoizeOne(descriptor.value);
  return descriptor;
}

// ./components/exampleComponent.js
import React from 'react';
import { memoized } from 'src/decorators';

class ExampleComponent extends React.Component {
  buildValuesFromProps() {
    const {
      watchedProp1,
      watchedProp2,
      watchedProp3,
      watchedProp4,
      watchedProp5,
    } = this.props
    return {
      value1: buildValue1(watchedProp1, watchedProp2),
      value2: buildValue2(watchedProp1, watchedProp3, watchedProp5),
      value3: buildValue3(watchedProp3, watchedProp4, watchedProp5),
    }
  }

  @memoized
  buildValue1(watchedProp1, watchedProp2) {
    return ...;
  }

  @memoized
  buildValue2(watchedProp1, watchedProp3, watchedProp5) {
    return ...;
  }

  @memoized
  buildValue3(watchedProp3, watchedProp4, watchedProp5) {
    return ...;
  }

  render() {
    const {
      value1,
      value2,
      value3
    } = this.buildValuesFromProps();

    return (
      
); } }

Преимущества в том, что вам не нужно кодировать тонны шаблона сравнения внутри getDerivedStateFromProps или componentWillReceiveProps, и вы можете пропустить инициализацию копирования и вставки внутри конструктора.

ПРИМЕЧАНИЕ:

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

getDerivedStateFromProps используется всякий раз, когда вы хотите обновить состояние перед рендерингом и обновить с условием props

GetDerivedStateFromPropd обновляет значение статистики с помощью значения props

прочитано https://www.w3schools.com/REACT/react_lifecycle.asp#: ~: text = Жизненный цикл% 20of% 20 Компоненты, Монтаж% 2C% 20 Обновление% 2C% 20и% 20 Размонтирование.

Как мы недавно писали в блоге React, в подавляющем большинстве случаев вам вообще не нужно getDerivedStateFromProps.

Если вы просто хотите вычислить производные данные, либо:

  1. Сделать прямо внутри рендер
  2. Или, если пересчет требует больших затрат, используйте помощник по мемоизации, например memoize-one.

Вот простейший пример «после»:

import memoize from "memoize-one";

class ExampleComponent extends React.Component {
  getDerivedData = memoize(computeDerivedState);

  render() {
    const derivedData = this.getDerivedData(this.props.someValue);
    // ...
  }
}

Проверьте этот раздел сообщения в блоге, чтобы узнать больше.

2022 WebDevInsider