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

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

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

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

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

React.js

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

Q&A

解決済

1回答

1083閲覧

constructor内だと値が取得できるのにrenderの中だとTypeError: Cannot read property 'xxx' of undefinedと出力される

Moai

総合スコア9

React Native

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

TypeScript

TypeScriptは、マイクロソフトによって開発された フリーでオープンソースのプログラミング言語です。 TypeScriptは、JavaScriptの構文の拡張であるので、既存の JavaScriptのコードにわずかな修正を加えれば動作します。

React.js

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

0グッド

0クリップ

投稿2020/11/07 17:06

編集2020/11/07 17:08

下記のコードのgetData()の中の console.log(data["users"]["userId"]["points"])では20と出力されます。

しかし、render()内の
<Text>{JSON.stringify(this.state.users.userId.points)}</Text>
を実行すると

TypeError: Cannot read property 'points' of undefined
というエラーが出力されます。

どのようにしたら、<Text>{JSON.stringify(this.state.users.userId.points)}</Text>
で20と出力できるのでしょうか?

import React from 'react'; import { Text, View, Button, StyleSheet, TouchableHighlight, FlatList} from 'react-native'; import { FloatingAction } from "react-native-floating-action"; import Icon from 'react-native-vector-icons/FontAwesome5'; import * as firebase from 'firebase'; import 'firebase/firestore'; import env from '../../env.json'; interface Props { navigation: any; route:any; authorId:string; postId:string; userId:string; win:string; wni:string; ideas:any; } interface State { actions:{ text:string, icon:JSX.Element, name:string, position:number }[], data:any, points:number users:any } const firebaseConfig = { apiKey: env.apiKey, authDomain: env.authDomain, databaseURL: env.databaseURL, projectId: env.projectId, storageBucket: env.storageBucket, messagingSenderId: env.messagingSenderId, appId: env.appId, measurementId: env.measurementId }; if (firebase.apps.length === 0) { firebase.initializeApp(firebaseConfig); } const db = firebase.firestore(); export class Rank extends React.Component<Props,State> { constructor(props){ super(props) this.state = { actions:[ { text: "Write down features", icon: <Icon name="list" size={20}/>, name: "feature", position: 2 }, { text: "Post your idea", icon: <Icon name="lightbulb" size={20}/>, name: "idea", position: 1 } ], data:{}, points:0, users:{} } this.getData() } async getData(){ let firestoreData = await db.collection("posts").doc(this.props.route.params.postId).get() let data = firestoreData.data() this.setState({ data:data, users:data["users"] }) console.log(data["users"]["userId"]["points"]) } render(){ return ( <View style={styles.backgroundImage} > <Text>{JSON.stringify(this.state.users.userId.points)}</Text> </View> ) } } const styles = StyleSheet.create({ backgroundImage: { ...StyleSheet.absoluteFillObject, }, })

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

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

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

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

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

guest

回答1

0

ベストアンサー

getData がasync関数なので、setStateが呼ばれるより前にrenderが呼ばれているのではないでしょうか

投稿2020/11/07 18:30

kazatsuyu

総合スコア158

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

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

Moai

2020/11/08 03:26

回答ありいがとうございます。 this.state.users.userIdまではrender内でも取得できているので、それはないと思うのですがどうなんでしょうか?
kazatsuyu

2020/11/08 05:51

TypeError: Cannot read property 'points' of undefined というエラーメッセージからは undefined.points を実行しようとしたことが読み取れます。つまり this.state.users.userId.points という式が undefined.points という式と同じになるのですから、 this.state.users.userId は undefined です。取得できていません。 users は {} で初期化されているのですから、 初期値のままだと this.state.users.userId は undefined となることは理解いただけますでしょうか。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問