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

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

新規登録して質問してみよう
ただいま回答率
85.35%
AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

React.js

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

Q&A

解決済

1回答

455閲覧

React.js で次のページにクラスインスタンスを渡す方法

gaegaelab

総合スコア9

AWS(Amazon Web Services)

Amazon Web Services (AWS)は、仮想空間を機軸とした、クラスター状のコンピュータ・ネットワーク・データベース・ストーレッジ・サポートツールをAWSというインフラから提供する商用サービスです。

React.js

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

0グッド

0クリップ

投稿2020/04/01 11:56

AWS Amplify + React.js でサインインがある Web ページを作っております。
サインイン時にパスワード未変更のユーザーであった場合、パスワード変更ページに飛ばしたいです。
この遷移でクラスインスタンスを受け渡ししたいのですが、方法はないでしょうか?

下記の Amplify の仕様のためにサインイン画面の Auth.signIn の戻り値を、クローンなどせず直接パスワード変更画面に渡す必要があります。
https://github.com/aws-amplify/amplify-js/issues/1715#issuecomment-537392659
localStorage に保存してみましたが、JSON 化されて別オブジェクトになるためか、上記イシューのエラーが発生します。
react-router-dom の history.push で渡してみましたが、クローンできないとエラーがでます。

index.js:1 DOMException: Failed to execute 'pushState' on 'History': Storage object could not be cloned.

下記で機能自体は実装できると思いますが、もっと良い方法があれば教えていただけると助かります。
1. Javascript のグローバル変数を作る
2. パスワード変更ページに Auth.signIn の戻り値ではなく、メールアドレスとパスワードを送って、
変更ページでもう一度 Auth.signIn をする。

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

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

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

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

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

hoshi-takanori

2020/04/01 12:11

「次のページに飛ばす」のは react-router を使って SPA にしてるんですよね。react の状態管理は理解されていますか? redux や context などでデータを持てば良いだけでは。
gaegaelab

2020/04/03 11:18

親コンポーネントに変数で持たせるだけにしました。お騒がせしました。
guest

回答1

0

自己解決

react-router-dom とか使わずにページの親のコンポーネントに変数として持たせることにしました。

投稿2020/04/03 11:16

gaegaelab

総合スコア9

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問