前提・実現したいこと
Nuxt.jsとfirebaseを使って道場生の情報として生年月日から年齢を計算するプログラムを作っています。計算まではうまく行きましたが、その計算結果を表示させることがうまくできなくて困っています。
発生している問題・エラーメッセージ
Cannot read property 'age' of undefined
該当のソースコード
js
1<template> 2略 3 <td>{{ this.age }}歳</td> 4略 5</template> 6 7export default { 8 data() { 9 return { 10 age: '', 11 }, 12 created() { 13 this.$store.dispatch('setStudentsRef', db.collection('students')); 14 // 年齢を計算 // 15 const studentRef = db.collection('students'); 16 studentRef.get().then(querySnapshot => { 17 querySnapshot.forEach(birthDayDocSnapshot => { 18 const birthDay = birthDayDocSnapshot.data().pickerDate; 19 const today = moment(); 20 let y = Math.floor(moment.duration(today.diff(birthDay)).as('months') / 12); 21 this.age = y; 22 }); 23 }); 24 },
試したこと
console.log(this.age)とするとちゃんと数字のデータはちゃんと取れています。
コールバック関数の問題でもなさそうですし、どうすればいいのか困っています。
補足情報(FW/ツールのバージョンなど)
ここにより詳細な情報を記載してください。
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2020/10/31 04:35
2020/11/01 05:45