質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
React Native

React Nativeは、ネイティブモバイルアプリ(iOS/Android)を作成できるJavaScriptフレームワークです。Reactと同じ設計のため、宣言的なコンポーネントでリッチなUIを開発することが可能です。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

Q&A

解決済

1回答

2219閲覧

react navigation画面遷移時のパラメーターの渡し方

tomaa

総合スコア84

React Native

React Nativeは、ネイティブモバイルアプリ(iOS/Android)を作成できるJavaScriptフレームワークです。Reactと同じ設計のため、宣言的なコンポーネントでリッチなUIを開発することが可能です。

React.js

Reactは、アプリケーションのインターフェースを構築するためのオープンソースJavaScriptライブラリです。

0グッド

0クリップ

投稿2020/08/03 13:33

前提・実現したいこと

react nativeを利用してアプリ開発をしています。

react navigationを利用して画面を遷移させています。
画面Aから画面Bへ遷移する際に、ある値をAからBへ渡してBの画面で表示したいのですが、うまく遷移できない状況です。

解決の方法ご存知の方おりましたら、ご教授いただけないでしょうか?

こちらのreact navigationの公式ドキュメントを参考にしてコードを作成しました。
Passing parameters to routes

発生している問題・エラーメッセージ

TypeError: undefined is not an object (evaluating 'route.params.test') This error is located at: in TestSecond (created by SceneView) in SceneView (created by CardContainer) in RCTView (created by CardContainer) in RCTView (created by CardContainer) in RCTView (created by Card) in RCTView (at createAnimatedComponent.js:151) in AnimatedComponent (created by PanGestureHandler) in PanGestureHandler (created by Card) in RCTView (at createAnimatedComponent.js:151) in AnimatedComponent (created by Card) in RCTView (created by Card) in Card (created by CardContainer) in CardContainer (created by CardStack) in RCTView (created by MaybeScreen) in MaybeScreen (created by CardStack) in RCTView (created by MaybeScreenContainer) in MaybeScreenContainer (created by CardStack) in CardStack (created by KeyboardManager) in KeyboardManager (created by Context.Consumer) in RNCSafeAreaView (at src/index.tsx:28) in SafeAreaProvider (created by Context.Consumer) in SafeAreaProviderCompat (created by StackView) in RCTView (created by StackView) in StackView (created by StackView) in StackView in Unknown (created by Navigator) in Navigator (created by NavigationContainer) in NavigationContainer in ExpoRoot (at renderApplication.js:40) in RCTView (at AppContainer.js:101) in DevAppContainer (at AppContainer.js:115) in RCTView (at AppContainer.js:119) in AppContainer (at renderApplication.js:39) renderRoot [native code]:0 runRootCallback [native code]:0 callFunctionReturnFlushedQueue [native code]:0

該当のソースコード

App.js

JS

1import { createAppContainer } from "react-navigation"; 2import { createStackNavigator } from "react-navigation-stack"; 3import TestFirst from "./src/screens/TestFirst"; 4import TestSecond from "./src/screens/TestSecond"; 5 6const App = createStackNavigator( 7 { 8 TestFirst: { screen: TestFirst }, 9 TestSecond: { screen: TestSecond }, 10 } 11); 12 13export default createAppContainer(App);

遷移元

JS

1import React from "react"; 2import { Text } from "react-native"; 3import { TouchableHighlight } from "react-native-gesture-handler"; 4 5export default function TestFirst(props) { 6 const { navigation } = props; 7 8 return ( 9 <TouchableHighlight 10 onPress={() => { 11 navigation.navigate("TestSecond", { test: "test" }); 12 }} 13 > 14 <Text>go to TestSecond</Text> 15 </TouchableHighlight> 16 ); 17}

遷移先

import React, { useState, useEffect } from "react"; import { Text } from "react-native"; export default function TestSecond(route) { const [text, setText] = useState(""); const { test } = route.params; useEffect(() => { setText(test); }, []); return <Text>{text}</Text>; }

補足情報(FW/ツールのバージョンなど)

node : 12.18.3
react native : 4.10.1
expo : 3.22.3
React Navigation: 4.3.7

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

自己解決

遷移先でのパラメーターの受け取り方が違っていました。

正しい書き方は以下の方法です

export default function TestSecond({navigation}) { const [text, setText] = useState(""); const { test } = navigation.state.params; useEffect(() => { setText(test); }, []); return <Text>{text}</Text>; }

投稿2020/08/03 23:46

tomaa

総合スコア84

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問