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

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

新規登録して質問してみよう
ただいま回答率
85.35%
データバインディング

データソースと、アプリケーションやウェブページ(ウェブアプリケーション)のユーザインタフェースを静的または動的に結合する技術です。

React.js

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

Q&A

解決済

1回答

2113閲覧

React: コンポーネント間(親->子)のデータの受け渡しができない

_dana

総合スコア15

データバインディング

データソースと、アプリケーションやウェブページ(ウェブアプリケーション)のユーザインタフェースを静的または動的に結合する技術です。

React.js

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

0グッド

0クリップ

投稿2021/04/27 03:40

編集2021/04/27 04:09

Reactで親コンポーネントのstateのデータを子コンポーネントに渡したいのですが、propsを使用してもうまくいきません。

調べたところ、propsがundefinedとなるエラーはよくあるようなのですが、props自体はundefinedではなく、指定したプロパティがundefinedになっています。

下記のコードではprops.valueがundefinedになっている状況です。

両コンポーネントともReact.Componentをextendsしたclassとして定義しています。
子コンポーネントをclassとして定義するべきでないという意見もありましたが、他の要素を考慮するとclassとして定義した方が都合がいいので他の方法を探しています。

js

1// 親コンポーネント 2export default class Parent extends React.Component { 3 ... 4 render() { 5 return ( 6 <Child value='props' /> 7 ) 8 } 9}

js

1// 子コンポーネント 2export default class Child extends React.Component { 3 constructor(props) { 4 super(props) 5 ... 6 } 7 ... 8 componentDidMount() { 9 console.log(this.props.value) 10 } 11}

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

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

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

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

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

nekoniki

2021/04/27 04:02

省略されていてわからないのですが、子のコンポーネントのコンストラクタでsuper(props)を実行してますか?
_dana

2021/04/27 04:08

ご指摘ありがとうございます。 質問内容を修正させていただきます。 super(props)は実行しております。
nekoniki

2021/04/27 04:24

提示いただいたコードで確認したところコンソールに"props"と表示されたので再現しませんでした。 省略している箇所に原因があるかと思います。
guest

回答1

0

ベストアンサー

定義は親コンポーネントに置きましょう。子から親に伝播できるのはイベントトリガーだけです。

js

1export default class Parent extends React.Component { 2 constructor(props) { 3 super(props) 4 ... 5 }

投稿2021/04/27 06:28

FKM

総合スコア3647

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

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

_dana

2021/04/27 10:15

親コンポーネントのpropsを子コンポーネントで使用できるということですか?
FKM

2021/04/27 14:10

親コンポーネントにおいて、その引数propsを用いて、子に要素を引き渡すことができる仕組みです。 React/React Nativeにおけるコンポーネント間での値・関数・中身の受け渡し) https://qiita.com/wktq/items/c079db14e6246e49fa48
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問