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

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

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

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

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

Onsen UI

HTML5で記述されたモバイルアプリの高速化、およびネイティブアプリライクなUIが作れるフレームワーク。 様々なJavaScriptフレームワークと併せて使用することができます。スマートフォン向けアプリ、Webサイトに必要なアニメーション、UI/UXを実装することが可能になります。

Monaca

「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

Q&A

0回答

370閲覧

axiosでサーバーから取得したjsonがv-forに反映されない

退会済みユーザー

退会済みユーザー

総合スコア0

Vue.js

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

JSON

JSON(JavaScript Object Notation)は軽量なデータ記述言語の1つである。構文はJavaScriptをベースとしていますが、JavaScriptに限定されたものではなく、様々なソフトウェアやプログラミング言語間におけるデータの受け渡しが行えるように設計されています。

Onsen UI

HTML5で記述されたモバイルアプリの高速化、およびネイティブアプリライクなUIが作れるフレームワーク。 様々なJavaScriptフレームワークと併せて使用することができます。スマートフォン向けアプリ、Webサイトに必要なアニメーション、UI/UXを実装することが可能になります。

Monaca

「Monaca」はiOS、Android、Windows向けのアプリ開発に対応した、Cordovaベースのモバイルアプリ開発プラットフォームです。HTML5、JavaScriptといったWeb標準技術を用いてモバイルアプリ開発を行うことができます。

0グッド

0クリップ

投稿2019/07/06 07:18

前提・実現したい

Monaca の Onsen UI V2 Vue Navigation テンプレートでアプリを開発しています。
サーバーから取得した json 形式のデータを v-for で繰り返し表示したいです。

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

{{ items }} でレスポンスデータ全件が表示されることは確認したのですが、
v-for のループ内では全く表示されません。

該当のソースコード

Page1.vue

js

1<template> 2 <v-ons-page> 3 {{ items }} 4 5 <li v-for="item in items"> 6 <v-ons-link @click="push(item.url)"> 7 {{ item.title }} 8 </v-ons-link> 9 </li> 10 </v-ons-page> 11</template> 12 13<script> 14 import customToolbar from './CustomToolbar'; 15 import page2 from './Page2'; 16 import axios from 'axios'; 17 18 export default { 19 data() { 20 return { 21 items: [] 22 } 23 }, 24 created() { 25 axios.get('https://xxxxxxxx.json') 26 .then(response => {this.items = response.data;}) 27 .catch(error => {console.log(error);}); 28 }, 29 methods: { 30 pop(){ 31 this.pageStack.pop(); 32 }, 33 push(url) { 34 this.pageStack.push({ 35 extends: page2, 36 data() { 37 return { 38 url: url 39 }; 40 } 41 }); 42 } 43 }, 44 props: ['pageStack'], 45 components: { customToolbar }, 46 key: 'key_page1', 47 } 48</script>

試したこと

data() 内の items 変数を以下のように書き換えると、配列に定義したデータ件数分だけ v-for が動作し、
以下の例だと3件分のデータが表示されるようになりました。

data() { return { items: [1,2,3] } },

アドバイスをいただけますと幸いです。よろしくお願いいたします。

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

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

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

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

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

KuwabataK

2019/07/06 12:21

response.dataが本当に配列で返ってきているかどうかを確認してみてはどうでしょうか?
退会済みユーザー

退会済みユーザー

2019/07/06 13:22

KuwabataK 様 コメントありがとうございます。 サンプルで下記のURLから取得した json で試して見ましたが同じ事象になりました。 https://qiita.com/api/v2/items?page=1
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

アカウントをお持ちの方は

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問