React Native — устанавливает состояние дочернего компонента непосредственно в родительском компоненте

#javascript #reactjs #react-native #components #state

#javascript #reactjs #react-native #Компоненты #состояние

Вопрос:

Я хочу задать вопрос. В случае, с которым я столкнулся, у меня есть много компонентов, которые используют состояние внутри. Поэтому я не объявляю состояние компонента в родительском компоненте, потому что я не хочу, чтобы родительский компонент имел несколько состояний. Мой вопрос в том, могу ли я установить значение состояния каждого дочернего компонента в родительском компоненте?

Вот пример кода того, что я хочу сделать:

 import React from 'react';
import {Switch} from 'react-native';

const Parents = () => {
  {/**
    Can I set state (setIsEnabled) directly on the parent component?

    For example:
    <Child active={true} onValueChange={() => setIsEnabled(!isEnabled)} />
  */}
  return (
    <Child active={true} />
  );
}

const Child = ({active}) => {
  const [isEnabled, setIsEnabled] = React.useState(active);

  return (
    <Switch
      trackColor={{
        false: 'rgba(0, 0, 0, 0.12)',
        true: 'rgba(66, 133, 244, 0.54)',
      }}
      thumbColor={isEnabled ? 'rgb(66, 133, 244)' : 'rgb(250, 250, 250)'}
      ios_backgroundColor="rgba(0, 0, 0, 0.12)"
      onValueChange={() => setIsEnabled(!isEnabled)}
      value={isEnabled}
    />
  );
}
 

Ответ №1:

Я думаю, это то, что вы ищете

 import React from 'react';
import {Switch} from 'react-native';

const Parents = () => {
  {/**
    Can I set state (setIsEnabled) directly on the parent component?

    For example:
    <Child active={true} onValueChange={() => setIsEnabled(!isEnabled)} />
  */}
  return (
    <Child active={true} />
  );
}

const Child = (props) => {
  const [isEnabled, setIsEnabled] = React.useState(props.active);

  return (
    <Switch
      trackColor={{
        false: 'rgba(0, 0, 0, 0.12)',
        true: 'rgba(66, 133, 244, 0.54)',
      }}
      thumbColor={isEnabled ? 'rgb(66, 133, 244)' : 'rgb(250, 250, 250)'}
      ios_backgroundColor="rgba(0, 0, 0, 0.12)"
      onValueChange={() => setIsEnabled(!isEnabled)}
      value={isEnabled}
    />
  );
}