В «const [isHungry, setIsHungry] = useState(true)» isHungry действительно ли постоянен?

#react-native #documentation

#react-native #Документация

Вопрос:

это быстрый вариант.

Согласно «https://reactnative.dev/docs/intro-react «

Возможно, вы заметили, что, хотя isHungry является const, его, по-видимому, можно переназначить!

ссылается на код:

 import React, { useState } from "react";
import { Button, Text, View } from "react-native";

const Cat = (props) => {
  const [isHungry, setIsHungry] = useState(true);

  return (
    <View>
      <Text>
        I am {props.name}, and I am {isHungry ? "hungry" : "full"}!
      </Text>
      <Button
        onPress={() => {
          setIsHungry(false);
        }}
        disabled={!isHungry}
        title={isHungry ? "Pour me some milk, please!" : "Thank you!"}
      />
    </View>
  );
}

const Cafe = () => {
  return (
    <>
      <Cat name="Munkustrap" />
      <Cat name="Spot" />
    </>
  );
}

export default Cafe;
  

согласно https://www.w3schools.com/js/js_const.asp

Вы можете изменять элементы постоянного массива

Так что, документация react неверна?

Ответ №1:

В перехватчиках react const предотвращает переназначение значения ссылки в той же области. Поэтому после рендеринга это можно рассматривать как новую переменную.

Комментарии:

1. Вы имеете в виду присвоение нового значения ссылке на массив? Я имею в виду присвоение значения элементу без изменения ссылки на массив.

2. При вызове setIsHungry компонент воспроизводится повторно, и следующий вызов useState возвращает новое значение. Так что в основном isHungry является постоянным.

3. Если бы у меня была деревянная доска, в которую всякий раз, когда я забиваю гвоздь, она заменяется новой доской с дополнительным гвоздем, я бы не использовал слово «постоянная» для описания этого (или области, в которую был забит гвоздь).

4. Я рекомендую вам сказать это и здесь, они тоже называют это неправильным. developer.mozilla.org/en-US/docs/Web/JavaScript/Reference /… :))