Как правильно установить состояние вложенных объектов в Reactjs?

Исключение нулевого указателя - это индикатор того, что вы используете объект, не инициализируя его.

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

public class Student {

    private int id;

    public int getId() {
        return this.id;
    }

    public setId(int newId) {
        this.id = newId;
    }
}

Приведенный ниже код дает вам исключение с нулевым указателем.

public class School {

    Student obj_Student;

    public School() {
        try {
            obj_Student.getId();
        }
        catch(Exception e) {
            System.out.println("Null Pointer ");
        }
    }
}

Поскольку вы используете Obj_Student, но вы забыли инициализировать его, как в правильном коде, показанном ниже:

public class School {

    Student obj_Student;

    public School() {
        try {
            obj_Student = new Student();
            obj_Student.setId(12);
            obj_Student.getId();
        }
        catch(Exception e) {
            System.out.println("Null Pointer ");
        }
    }
}
-1
задан Dhruvil Shah 8 April 2019 в 06:04
поделиться

1 ответ

Есть несколько способов сделать то, что вы пытаетесь сделать, как уже упоминали другие. Но правильный способ сделать конкретный способ, который вы упомянули, заключается в использовании prevState, поскольку this.state ненадежен (потому что он асинхронный).

Вот рабочие примеры:

this.setState((prevState, props) => ({
  some: {
    ...prevState.some,
    z: {
      ...prevState.some.z,
      a: 1111
    }
  }
}))

Отличное объяснение: https://teamtreehouse.com/community/react-docs-now-recomlies-using-function-with -prevstate-inside-of-settate

0
ответ дан Hybrid 8 April 2019 в 06:04
поделиться
Другие вопросы по тегам:

Похожие вопросы: