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

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

新規登録して質問してみよう
ただいま回答率
87.20%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

解決済

変数を定義している(?)のに、xxx is not definedとエラーが出る

akarisano
akarisano

総合スコア30

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

1回答

0評価

0クリップ

185閲覧

投稿2022/04/30 05:07

前提

Vue3でFirestoreから取得してきたデータの配列を、変数で定義した配列に追加していきたいです。

実現したいこと

  • 前提通り、xxxという名前の変数に配列を入れたい

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

Uncaught (in promise) ReferenceError: xxx is not defined

該当のソースコード

js:xxxView.vue

<template> <div v-for="yyy in xxx" :key="yyy.name"> {{ yyy.name }} {{ yyy.number}} </div> </template> <script> import db from "../firebase.js"; import { collection, getDocs} from "firebase/firestore"; export default { data() { return { xxx: [{ 'number': Number, 'name': String }] /* xxxで入れたいこと [ {number => 0, name => 'a'} {number => 1, name => 'b'} ] */ }; }, mounted: async function () { const hoge = await getDocs(collection(db, 'events', this.$route.params.id, 'subcollection')) hoge.forEach((doc) => { //console.log(this.xxx) this.xxx[xxx.length] = doc.data() //ここでエラーが起きる }) }, }; </script>

試したこと

変数が定義されていないからという解説は見たのですが、data()で定義してあると思うので、なにが原因なのかさっぱり分かりません。

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

  • Vue 3.2.25

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

qnoir

2022/04/30 05:13

this.xxx[xxx.length] はどのような意図なのでしょうか。 xxxという配列の最後の要素を、 doc.data() に置き換えたい、という意味でしょうか。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。