React Native: как отправить значение TextInput в React Native?

Я пытаюсь отправить значение TextInput на другой экран, может кто-нибудь помочь мне, пожалуйста. Вот мой код:

  const [text, setText] = useState ( ' ');
  return (
<>
        <TextInput style = {styles.input}
          underlineColorAndroid = "transparent"
          placeholder = "   Type "
          placeholderTextColor = "#9a73ef"
          autoCapitalize = "none"
          onChangeText = {text => setText(text)}
          //defaultValue = {text}
        />
 <Button
        title = "Go to Details"
        onPress = {() => navigation.navigate('Details')}
      />
-----

это мой экран Detais:

function DetailsScreen(  {text}) {
  return (

<View>


  <Text> Hello this is Details  Screen + { text }</Text>
</View>
   
  );
}

не может принимать никакого значения, даже сделал опору

Где отображается DetailsScreen? Текст передается?

evolutionxbox 23.12.2020 11:59
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
1
1
315
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

Вы должны передать параметр, как показано ниже

 <Button
        title = "Go to Details"
        onPress = {() => navigation.navigate('Details',{text:text})}
      />

И на экране сведений вы должны получить его, как показано ниже.

function DetailsScreen(  {route}) {
  return (
<View>
  <Text> Hello this is Details  Screen + { route.params.text }</Text>
</View>
  );
}

Обратитесь к официальной документации

о, спасибо большое, получилось? но можно я задам тебе вопрос? как работает маршрут? это как опора?

Feliks Bekeshov 23.12.2020 12:05

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

Guruparan Giritharan 23.12.2020 12:08

ох, хорошо . я попробовал эту технику с моим вторым TextInput, который является числовым: onChangeText = {num => setNum(num)} , а на экране Details это выглядит так: <Text> Здравствуйте, это Details Screen + {route.params.num}</Text > а работы нет..(

Feliks Bekeshov 23.12.2020 12:10

вы прошли как navigation.navigate('Details',{text:text,num:num})} ?

Guruparan Giritharan 23.12.2020 12:13

Другие вопросы по теме