#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 /… :))