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

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

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

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

オブジェクト

オブジェクト指向において、データとメソッドの集合をオブジェクト(Object)と呼びます。

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

Q&A

解決済

1回答

6047閲覧

親から子コンポーネントに渡した値が{__ob__: observer}になり値を取れない

widget11

総合スコア221

Vue.js

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

オブジェクト

オブジェクト指向において、データとメソッドの集合をオブジェクト(Object)と呼びます。

配列

配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

0グッド

0クリップ

投稿2021/05/23 19:00

編集2021/05/24 09:18

親コンポーネントでdata属性のプロパティに配列を代入。
その後、props経由で子コンポーネントにその配列を渡しているのですが、developer toolでログを確認すると{ob: observer}という謎の値に変わっており、更にそのobserverに対してforeachなどしても、値を取り出せません。

修正版

//edit.vue <template> <v-app id="edit"> <Search :categories="categories"></Search> </v-app> </template> <script> export default{ data: function() { return{ categories: [], } },    beforeCreate: function() { axios .get('http://localhost:3000//users/'+ id +'/edit.json') .then((response) => {     response.data.categories.forEach((value) => {   this.categories.push({ id: value.id, name:value.name })   }      );    } } </script>
//search.vue props: { categories: Array, default: [] }, mounted: function(){ console.log(this.categories); this.categories.forEach((value) => {  console.log(value.name);  this.selected.categories.push({ id: value.id, name:value.name }) } }

イメージ説明

このobserverなるオブジェクト自体には[{id=>1,name=>"aa"}]という親コンポーネントで代入した値が入っているみたいなのですが、
その後foreachで展開しようとすると、consoleにログが表示されません。
Arrayオブジェクトではないので当然かもしれませんが、どうしたらobserverからこのidとnameを取り出せるでしょうか?
後そもそも何故、Arrayで渡したオブジェクトがこの様なobserverというオブジェクトになってしまうのでしょうか?
よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

ライフサイクルフックのbeforeCreateはインスタンス生成直後なので、何もDOMが生成されていないどころか、変数dataも生成されていない状態です。

なので、普通にmountedで問題ないのでは?

投稿2021/05/24 02:58

FKM

総合スコア3647

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

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

widget11

2021/05/24 03:32

回答ありがとうございます!! edit.vueのbeforecreatedをmountedに変更してみたのですが、 observerという値は変わらないですね。。。 edit.vueとsearch.vueのライフサイクルフックに関して、親のライフサイクルに対して子はどの様にすればいいといったベストプラクティスみたいなのはあるのでしょうか? 確かにライフサイクル周りでこの様な値が入ってきていると思い、、、お手数をおかけしますがよろしくお願いします。
FKM

2021/05/24 04:17 編集

observerはフック処理前にデータを読み込めていない状態に表示される現象です。jsonを読み込んだりするとよくそれが起きるので、その場合はaxiosで制御したりします。つまり、子にデータが行き渡る前の段階、親へのデータインポート段階で問題が発生しています。 あとcategories: []としてみてはどうでしょうか?
widget11

2021/05/24 09:21

ご回答ありがとうございます。 axiosで制御というと具体的にどの様にすれば良いのでしょうか? 添付コードを編集してaxiosで取得している部分を記載しましたが、データ処理できたらみたいな処理の仕方を思いつかず。。。 何度もお伺いして申し訳ないですがよろしくお願いします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問